golang中的read会发生阻塞吗?可能很多人对此没有深入了解过,故而小编总结了这篇文章,通过这文章的讲解,希望你能够收获更多知识。
Go语言中Reader接口定义了一个Read操作,实现了Reader接口的都有Read这个函数。
接口的定义如下:
type Reader interface { Read(p []byte) (n int, err error) }
一次Read调用最多读取len(p)字节的数据到缓冲区p中
n表示这一次实际读取到字节数,(0 <= n <= len(p))
err 表示这次读取操作的报错(如果有的话,没有则是nil)
即使读取到的字节数n小于len(p),在函数调用过程中调用主体也可能使用全部的p的空间(不知道这个说明是想表达什么)
当read到数据的时候,即使不够len(p)(此时IO缓存中没有数据了),Read操作通常会直接返回获取到的数据而不是继续等待IO缓存中到达更多的数据
当Read操作在成功读取到n字节数据后遇到一个错误或者文件的末尾,它将会返回读取的n字节数据,然后err的返回可能有两种操作:
在本次Read操作的时候返回n(>0)和err(非nil)
或者本次Read操作返回n(>0)和nil,下一次调用的时候再返回0和err(非nil)
这两种操作都是可能的,所以调用者永远应该首先按照n>0来判定是否有数据返回,而不是先判定err是否为nil
举个例子说明,当某次调用到达文件末尾并且还读取到了n字节数据的时候,Reader的实现可能有两种方式:
当前调用返回n和EOF error
当前调用返回n和nil,下次调用返回0和EOF
Read的实现不应该返回0和nil,也就是当返回0的时候就应该返回一个非nil的error,除非缓冲空间的大小为0,然后调用者应该忽略调用0和nil这种返回值组合,当作什么都没发生,特别强调一下,这个返回并不表示EOF了
看完上述内容,你们对golang中的read有进一步的了解吗?如果还想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。