io.Seeker 通过 Seek(offset, whence) 灵活定位文件读写位置,offset 为偏移量,whence 指定参考点(SeekStart/Current/End),返回新绝对偏移量;不支持 seek 的对象(如管道)会报错,且需注意缓冲区一致性。

使用 io.Seeker 可以在文件中灵活跳转读写位置,核心是调用 Seek() 方法。它不负责读写,只改变“当前偏移量”,后续的 Read() 或 Write() 都从新位置开始。
Seek(offset int64, whence int) (int64, error) 中:
io.SeekStart:从文件开头算起(offset ≥ 0)io.SeekCurrent:从当前位置算起(offset 可正可负)io.SeekEnd:从文件末尾算起(offset 通常为负,如 -1 表示倒数第 1 字节)假设打开一个文件:f, _ := os.Open("data.txt")
f.Seek(0, io.SeekStart)
f.Seek(10, io.SeekStart)
f.Seek(5, io.SeekCurrent)
f.Seek(-1, io.SeekCurrent)
f.Seek(-3, io.SeekEnd)
Seek() 返回的是**新的绝对偏移量**(从文件开头算),不是 offset 本身。它可能成功但返回值超出文件长度——这不报错,只是下次 Read() 会立刻返回 io.EOF。
立即学习“go语言免费学习笔记(深入)”;
f.Seek(200, io.SeekStart) 会返回 200,无错误buf := make([]byte, 1); f.Read(buf) 会返回 0, io.EOF
f.Stat().Size(),别依赖 Seek 返回值判断长度io.Seeker 常见于需要随机访问的场景(如解析二进制协议、日志回溯、断点续传)。注意:
Seek() 没问题;但对管道、网络连接等非 seekable 对象会返回 io.SeekError
*os.File,Seek() 是系统调用,开销低;但如果是包装过的 reader(如 bufio.Reader),需先 Reset() 或用 UnreadByte() 等辅助,否则缓冲区内容和文件位置可能不一致Seek() 定位,尤其用 os.O_RDWR 打开时,避免覆盖或追加意外基本上就这些。掌握 offset 和 whence 的组合逻辑,再留意底层对象是否支持 seek,就能稳稳控制文件游标了。
以上就是如何使用Golang io.Seeker在文件中定位_Golang io文件定位技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号