共计 1568 个字符,预计需要花费 4 分钟才能阅读完成。
// ReadOne 读取到 file 中,再利用 ioutil 将 file 间接读取到 []byte 中
func ReadOne() string {file, err := os.Open("file/test")
if err != nil {fmt.Println("read file fail", err)
return ""
}
defer file.Close()
content, err := ioutil.ReadAll(file)
if err != nil {fmt.Println("read to fd fail", err)
return ""
}
return string(content)
}
// WriteOne 应用 bufio.NewWriter 写文件
func WriteOne() {
fileName := "file/test3"
file, err3 := os.Create(fileName) // 创立文件
defer file.Close()
if err3 != nil {fmt.Println("create file fail")
}
writer := bufio.NewWriter(file) // 创立新的 Writer 对象
_, err := writer.WriteString("bufferedn")
if err != nil {fmt.Println("write fail")
}
writer.Flush()}
// ReadTwo 利用 ioutil.ReadFile 间接从文件读取到 []byte 中
func ReadTwo() string {f, err := ioutil.ReadFile("file/test")
if err != nil {fmt.Println("read fail", err)
}
return string(f)
}
// WriteTwo 应用 ioutil.WriteFile 写文件
func WriteTwo() {
fileName := "file/test2"
strTest := "测试测试"
var d = []byte(strTest)
err := ioutil.WriteFile(fileName, d, 0666)
if err != nil {fmt.Println("write fail")
}
fmt.Println("write success")
}
图一、io.Reader/Writer 之间的关系
io 库
io 库属于底层接口定义库。它的作用次要是定义个 I/O 的根本接口和个根本常量,并解释这些接口的性能。在理论编写代码做 I/O 操作时,这个库个别只用来调用它的常量和接口定义,比方用 io.EOF 判断是否曾经读取完,用 io.Reader 做变量的类型申明。
os 库
os 库次要是解决操作系统操作的,它作为 Go 程序和操作系统交互的桥梁。创立文件、关上或者敞开文件、Socket 等等这些操作和都是和操作系统挂钩的,所以都通过 os 库来执行。
ioutil 库
ioutil 库是一个有工具包,它提供了很多应用的 IO 工具函数,例如 ReadAll、ReadFile、WriteFile、ReadDir。惟一须要留神的是它们都是一次性读取和一次性写入,所以应用时,尤其是把数据从文件里一次性读到内存中时须要留神文件的大小。
bufio 库
bufio,能够了解为在 io 库的根底上额定封装加了一个缓存层,它提供了很多按行进行读写的函数,从 io 库的按字节读写变为按行读写对写代码来说还是不便了不少。
bytes 和 strings 库
bytes 和 strings 库里的 bytes.Reader 和 string.Reader,它们都实现了 io.Reader 接口,也都提供了 NewReader 办法用来从 []byte 或者 string 类型的变量间接构建出相应的 Reader 实现。
参考:
https://www.cnblogs.com/wangq…
https://www.jb51.net/article/…
正文完