Go语言中Reader接口定义了一个Read操作,实现了Reader接口的都有Read这个函数。 (推荐学习:go)
接口的定义如下:
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会阻塞么的详细内容。更多信息请关注PHP中文网其他相关文章!