12.7-12.12

This commit is contained in:
Unknwon
2015-11-18 19:06:39 -05:00
parent 145cb40146
commit 48d5b9db25
10 changed files with 33 additions and 28 deletions

View File

@@ -3,6 +3,7 @@
例子程序 `io_interfaces.go` 很好的阐述了 io 包中的接口概念。
示例 12.15 [io_interfaces.go](examples/chapter_12/io_interfaces.go)
```go
// interfaces being used in the GO-package fmt
package main
@@ -22,7 +23,6 @@ func main() {
fmt.Fprintf(buf, "%s\n", "hello world! - buffered")
buf.Flush()
}
```
输出:
@@ -31,10 +31,11 @@ func main() {
hello world! - unbuffered
hello world! - buffered
```
下面是 `fmt.Fprintf()` 函数的实际签名
```go
func Fprintf(w io.Writer, format string, a ...interface{}) (n int, err error)
func Fprintf(w io.Writer, format string, a ...interface{}) (n int, err error)
```
其不是写入一个文件,而是写入一个 `io.Writer` 接口类型的变量,下面是 `Writer` 接口在 io 包中的定义:
@@ -43,7 +44,8 @@ type Writer interface {
Write(p []byte) (n int, err error)
}
```
`fmt.Fprintf()` 依据指定的格式向第一个参数内写入字符串,第一参数必须实现了 `io.Writer` 接口。`Fprintf()` 能够写入任何类型,只要其实现了 `Write` 方法,包括 `os.Stdout`,文件(例如 os.File管道网络连接通道等等同样的也可以使用 bufio 包中缓冲写入。bufio 包中定义了 `type Writer struct{...}`
`fmt.Fprintf()` 依据指定的格式向第一个参数内写入字符串,第一参数必须实现了 `io.Writer` 接口。`Fprintf()` 能够写入任何类型,只要其实现了 `Write` 方法,包括 `os.Stdout`,文件(例如 os.File管道网络连接通道等等同样的也可以使用 bufio 包中缓冲写入。bufio 包中定义了 `type Writer struct{...}`
bufio.Writer 实现了 Write 方法:
@@ -56,14 +58,15 @@ func (b *Writer) Write(p []byte) (nn int, err error)
```go
func NewWriter(wr io.Writer) (b *Writer)
```
其适合任何形式的缓冲写入。
在缓冲写入的最后千万不要忘了使用 `Flush()`,否则最后的输出不会被写入。
在 15.2-15.8 章节,我们将使用 `fmt.Fprint` 函数向 `http.ResponseWriter` 写入,其同样实现了 io.Writer 接口。
**练习 12.7**[remove_3till5char.go](exercises/chapter_12/remove_3till5char.go)
下面的代码有一个输入文件 `goprogram.go`,然后以每一行为单位读取,从读取的当前行中截取第 3 到第 5 的字节写入另一个文件。然而当你运行这个程序,输出的文件却是个空文件。找出程序逻辑中的 bug修正它并测试。
```go