流操作
可讀可寫stream - 原理
I/O操作也叫輸入輸出操作.其中I是指Input,O是指Output,用於讀或者寫數據的,有些語言中也叫流操作, 是指數據通信的通道.
Golang 標准庫對 IO 的抽象非常精巧,各個組件可以隨意組合,可以作為接口設計的典范.
Go原生的pkg中有一些核心的interface,其中io.Reader/Writer是比較常用的接口. Go Writer 和 Reader接口的設計遵循了Unix的輸入和輸出,一個程序的輸出可以是另外一個程序的輸入.
// io.Reader/Writer,有幾個常用的實現:
net.Conn: 網絡
os.Stdin, os.Stdout, os.Stderr: console終端標准輸出,err
os.File: 網絡、標准輸入輸出、文件的流讀取
strings.Reader: 把字符串抽象成Reader
bytes.Reader: 把[]byte抽象成Reader
bytes.Buffer: 把[]byte抽象成Reader和Writer
bufio.Reader/Writer: 抽象成帶緩沖的流讀取(比如按行讀寫)
go文件方法繼承 -- 源碼
讀文件 -- 使用
//os.OpenFile
f, _ := os.OpenFile("/etc/hosts", os.O_RDONLY, 0600)
buf := make([]byte, 128)
n, _ := f.Read(buf)
fmt.Println(string(buf[:n]))
//os.Open - 使用數組
f, _ := os.Open("/etc/hosts")
var buf [128]byte
n, _ := f.Read(buf[:])
fmt.Println(string(buf[:n]))
//os.Open - 直接初始化切片
f, err := os.Open("/etc/hosts")
buf := make([]byte, 5)
n, err := f.Read(buf)
fmt.Println(string(buf[:n]))
//f.Read讀一個完整的文件
f, _ := os.Open("/etc/hosts")
buf := make([]byte, 128)
for {
n, err := f.Read(buf)
fmt.Println(string(buf[:n]))
if err==io.EOF{
break
}
}
//ioutil.ReadFile
buf, _ := ioutil.ReadFile("/etc/hosts")
fmt.Println(string(buf))
//ioutil.ReadAll
f, _ := os.OpenFile("/etc/hosts", os.O_RDONLY, 0600)
buf, _ := ioutil.ReadAll(f)
fmt.Println(string(buf))
// bufio.NewReader
r := strings.NewReader("Go is a general-purpose language designed with systems programming in mind.")
buf, _ := ioutil.ReadAll(r)
fmt.Println(string(buf))
json/struct操作
讀寫 - 常見go類型
Golang 中使用 JSON 的小技巧
Go - 如何解析 JSON 數據?
寫字符串
寫對象
寫數組
寫字段嵌套的數組
// 寫數組
user := []string{
"m1",
"m2",
"m3",
}
f, _ := os.Create("./data.txt")
b, _ := json.Marshal(user)
f.Write(b)
defer f.Close()
//讀數組
var arr []string
b, _ := ioutil.ReadFile("./data.txt")
json.Unmarshal(b, &arr)
fmt.Printf("%T",arr)
//寫對象
type user struct {
Name string `json:"name"`
Age int `json:"age"`
}
u1 := user{
Name: "m1",
Age: 22,
}
f, _ := os.Create("./data.txt")
b, _ := json.Marshal(u1)
f.Write(b)
defer f.Close()
//讀對象
var obj user
b, _ := ioutil.ReadFile("./data.txt")
json.Unmarshal(b, &obj)
fmt.Printf("%T,%v", obj, obj)
//寫[obj,]
type user struct {
Name string `json:"name"`
Age int `json:"age"`
}
m:= []user{
{"m1",1},
{"m2",2},
}
f, _ := os.Create("./data.txt")
b, _ := json.Marshal(m)
f.Write(b)
defer f.Close()
//讀[obj,]
var arr []user
b, _ := ioutil.ReadFile("./data.txt") //會自動幫你初始化arr
json.Unmarshal(b, &arr)
fmt.Printf("%T,%v", arr, arr)
// 一個簡易下載器
resp, _ := http.Get("https://mojotv.cn/assets/image/logo01.png")
f, _ := os.Create("./a.jpg")
defer f.Close()
io.Copy(f, resp.Body)
文件打開模式
創建/寫文件
// golang創建文本文件
f,err := os.Create(fileName)
defer f.Close()
if err !=nil {
fmt.Println(err.Error())
} else {
_,err=f.Write([]byte("要寫入的文本內容"))
checkErr(err)
}
// golang讀取文本文件
f, err := os.OpenFile(fileName, os.O_RDONLY,0600)
defer f.Close()
if err !=nil {
fmt.Println(err.Error())
} else {
contentByte,err=ioutil.ReadAll(f)
checkErr(err)
fmt.Println(string(contentByte))
}
OpenFile用法:os.OpenFile(文件名,打開方式,打開模式)
//打開方式
const (
//只讀模式
O_RDONLY int = syscall.O_RDONLY // open the file read-only.
//只寫模式
O_WRONLY int = syscall.O_WRONLY // open the file write-only.
//可讀可寫
O_RDWR int = syscall.O_RDWR // open the file read-write.
//追加內容
O_APPEND int = syscall.O_APPEND // append data to the file when writing.
//創建文件,如果文件不存在
O_CREATE int = syscall.O_CREAT // create a new file if none exists.
//與創建文件一同使用,文件必須存在
O_EXCL int = syscall.O_EXCL // used with O_CREATE, file must not exist
//打開一個同步的文件流
O_SYNC int = syscall.O_SYNC // open for synchronous I/O.
//如果可能,打開時縮短文件
O_TRUNC int = syscall.O_TRUNC // if possible, truncate file when opened.
)
//打開模式
const (
ModeDir FileMode = 1 << (32 - 1 - iota) // d: is a directory 文件夾模式
ModeAppend // a: append-only 追加模式
ModeExclusive // l: exclusive use 單獨使用
ModeTemporary // T: temporary file (not backed up) 臨時文件
ModeSymlink // L: symbolic link 象征性的關聯
ModeDevice // D: device file 設備文件
ModeNamedPipe // p: named pipe (FIFO) 命名管道
ModeSocket // S: Unix domain socket Unix 主機 socket
ModeSetuid // u: setuid 設置uid
ModeSetgid // g: setgid 設置gid
ModeCharDevice // c: Unix character device, when ModeDevice is set Unix 字符設備,當設備模式是設置Unix
ModeSticky // t: sticky 粘性的
// Mask for the type bits. For regular files, none will be set. bit位遮蓋.不變的文件設置為none
ModeType = ModeDir | ModeSymlink | ModeNamedPipe | ModeSocket | ModeDevice
ModePerm FileMode = 0777 // Unix permission bits 權限位.
)
// golang寫入文本文件
f, err := os.OpenFile(fileName, os.O_WRONLY|os.O_TRUNC, 0600)
defer f.Close()
if err != nil {
fmt.Println(err.Error())
} else {
_,err=f.Write([]byte("要寫入的文本內容"))
checkErr(err)
}