go 语言file Seek( )函数用法
原文: https://studygolang.com/articles/2271
package main import ( "fmt" "strings" "log" ) func main() { reader := strings.NewReader("Go语言学习园地") reader.Seek(2, 0) r, _, _ := reader.ReadRune() fmt.Printf("%c\n", r) str := "Go语言学习园地" log.Println([]byte(str)) }
——————–
读者是否发现,其实ReaderFrom和WriterTo接口的方法接收的参数是io.Reader和io.Writer类型。根据io.Reader和io.Writer接口的讲解,对该接口的使用应该可以很好的掌握。
这里只提供简单的一个示例代码:将一段文本输出到标准输出
reader := bytes.NewReader([]byte(“Go语言学习园地”))
reader.WriteTo(os.Stdout)
通过io.ReaderFrom和io.WriterTo的学习,我们知道,如果这样的需求,可以考虑使用这两个接口:“一次性从某个地方读或写到某个地方去。”
## Seeker接口 ##
接口定义如下:
type Seeker interface { Seek(offset int64, whence int) (ret int64, err error) }
官方文档中关于该接口方法的说明:
> Seek 设置下一次 Read 或 Write 的偏移量为 offset,它的解释取决于 whence: 0 表示相对于文件的起始处,1 表示相对于当前的偏移,而 2 表示相对于其结尾处。 Seek 返回新的偏移量和一个错误,如果有的话。
也就是说,Seek方法用于设置偏移量的,这样可以从某个特定位置开始操作数据流。听起来和ReaderAt/WriteAt接口有些类似,不过Seeker接口更灵活,可以更好的控制读写数据流的位置。
简单的示例代码:获取倒数第二个字符(需要考虑UTF-8编码,这里的代码只是一个示例
————-
**小贴士**
whence的值,在os包中定义了相应的常量,应该使用这些常量
const (
SEEK_SET int = 0 // seek relative to the origin of the file
SEEK_CUR int = 1 // seek relative to the current offset
SEEK_END int = 2 // seek relative to the end
)
## Closer接口 ##
接口定义如下:
type Closer interface { Close() error }
该接口比较简单,只有一个Close()方法,用于关闭数据流。