Skip to content

Commit

Permalink
Update 11.8.md (unknwon#480)
Browse files Browse the repository at this point in the history
fix some bug
  • Loading branch information
Sarlor authored and unknwon committed May 22, 2018
1 parent 280df5b commit 467777b
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions eBook/11.8.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,9 @@ type Writer interface {
}
```

只要类型实现了读写接口,提供 `Read()``Write` 方法,就可以从它读取数据,或向它写入数据。一个对象要是可读的,它必须实现 `io.Reader` 接口,这个接口只有一个签名是 `Read(p []byte) (n int, err error)` 的方法,它从调用它的对象上读取数据,并把读到的数据放入参数中的字节切片中,然后返回读取的字节数和一个 `error` 对象,如果没有错误发生返回 'nil',如果已经到达输入的尾端,会返回 `io.EOF("EOF")`,如果读取的过程中发生了错误,就会返回具体的错误信息。类似地,一个对象要是可写的,它必须实现 `io.Writer` 接口,这个接口也只有一个签名是 `Write(p []byte) (n int, err error)` 的方法,它将指定字节切片中的数据写入调用它的对象里,然后返回实际写入的字节数一个 `error` 对象(如果没有错误发生就是 `nil`)。
只要类型实现了读写接口,提供 `Read()``Write` 方法,就可以从它读取数据,或向它写入数据。一个对象要是可读的,它必须实现 `io.Reader` 接口,这个接口只有一个签名是 `Read(p []byte) (n int, err error)` 的方法,它从调用它的对象上读取数据,并把读到的数据放入参数中的字节切片中,然后返回读取的字节数和一个 `error` 对象,如果没有错误发生返回 `nil`,如果已经到达输入的尾端,会返回 `io.EOF("EOF")`,如果读取的过程中发生了错误,就会返回具体的错误信息。类似地,一个对象要是可写的,它必须实现 `io.Writer` 接口,这个接口也只有一个签名是 `Write(p []byte) (n int, err error)` 的方法,它将指定字节切片中的数据写入调用它的对象里,然后返回实际写入的字节数和一个 `error` 对象(如果没有错误发生就是 `nil`)。

`io` 包里的 `Readers``Writers` 都是不带缓冲的,`bufio` 包里提供了对应的带缓冲的操作,在读写 `UTF-8` 编码的文本文件时它们尤其有用。在 第12章 我们会看到很多在实战使用它们的例子
`io` 包里的 `Readers``Writers` 都是不带缓冲的,`bufio` 包里提供了对应的带缓冲的操作,在读写 `UTF-8` 编码的文本文件时它们尤其有用。在 第12章 我们会看到很多在实战中使用它们的例子

在实际编程中尽可能的使用这些接口,会使程序变得更通用,可以在任何实现了这些接口的类型上使用读写方法。

Expand All @@ -26,4 +26,4 @@ type Writer interface {

- [目录](directory.md)
- 上一节:[第一个例子:使用Sorter接口排序](11.7.md)
- 下一节:[空接口](11.9.md)
- 下一节:[空接口](11.9.md)

0 comments on commit 467777b

Please sign in to comment.