时间:2021-05-22
前言
bufio包实现了带缓冲的I/O,它封装了io.Reader和io.Writer对象,然后创建了另外一种对象(Reader或Writer)实现了相同的接口,但是增加了缓冲功能。
首先来看没有缓冲功能的Write(os包中)方法,它会将数据直接写到文件中。
package mainimport ( "os" "fmt")func main() { file, err := os.OpenFile("a.txt", os.O_CREATE|os.O_RDWR, 0666) if err != nil { fmt.Println(err) } defer file.Close() content := []byte("hello world!") if _, err = file.Write(content); err != nil { fmt.Println(err) } fmt.Println("write file successful")}接着看一个错误的使用带缓冲的Write方法例子,当下面的程序执行后是看不到写入的数据的。
package mainimport ( "os" "fmt" "bufio")func main() { file, err := os.OpenFile("a.txt", os.O_CREATE|os.O_RDWR, 0666) if err != nil { fmt.Println(err) } defer file.Close() content := []byte("hello world!") newWriter := bufio.NewWriter(file) if _, err = newWriter.Write(content); err != nil { fmt.Println(err) } fmt.Println("write file successful")}为什么会在文件中看不到写入的数据呢,我们来看看bufio中的Write方法。
func (b *Writer) Write(p []byte) (nn int, err error){ for len(p) > b.Available() && b.err == nil { var n int if b.Buffered() == 0{ n,b.err =b.wr.Write(p) }else { n = copy(b.buf[b.n:],p) b.n+=n b.Flush() } nn+=n p=p[n:] } if b.err!=nil { return nn, b.err } n:= copy(b.buf[b.n:],p) b.n+= n nn+=n return nn,nil}Write方法首先会判断写入的数据长度是否大于设置的缓冲长度,如果小于,则会将数据copy到缓冲中;当数据长度大于缓冲长度时,如果数据特别大,则会跳过copy环节,直接写入文件。其他情况依然先会将数据拷贝到缓冲队列中,然后再将缓冲中的数据写入到文件中。
所以上面的错误示例,只要给其添加Flush()方法,将缓存的数据写入到文件中。
package mainimport ( "os" "fmt" "bufio")func main() { file, err := os.OpenFile("./a.txt", os.O_CREATE|os.O_RDWR, 0666) if err != nil { fmt.Println(err) } defer file.Close() content := []byte("hello world!") newWriter := bufio.NewWriterSize(file, 1024) if _, err = newWriter.Write(content); err != nil { fmt.Println(err) } if err = newWriter.Flush(); err != nil { fmt.Println(err) } fmt.Println("write file successful")}总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近用golang写了一个处理文件的脚本,由于其中涉及到了文件读写,开始使用golang中的io包,后来发现golang中提供了一个bufio的包,使用这个包可
前言什么是TCP粘包问题以及为什么会产生TCP粘包,本文不加讨论。本文使用golang的bufio.Scanner来实现自定义协议解包。下面话不多说了,来一起看
前言bufio模块是golang标准库中的模块之一,主要是实现了一个读写的缓存,用于对数据的读取或者写入操作。该模块在多个涉及io的标准库中被使用,比如http
今天我们讲解的是golang标准库里边的io/ioutil包–也就是packageio/ioutil1.ioutil.ReadDir(dirnamestring
Go语言在进行文件操作的时候,可以有多种方法。最常见的比如直接对文件本身进行Read和Write;除此之外,还可以使用bufio库的流式处理以及分片式处理;如果