我有一个 io.readwritecloser ,我想在不推进读者的情况下窥视它,
所以我正在使用
bi := bufio.NewReader(i) bi.Peek(1)
到目前为止一切顺利,但后来当我想重用原始的 io.readwritecloser (i) 时,它只有 eof。
所以我的问题是如何从 bufio.reader 转换回 io.readwritecloser
由于 bufio.reader 缓冲来自底层读取器的数据,因此应用程序必须在调用 peek 后从 bufio.reader 读取数据。
要获得执行此操作的 io.readwritecloser,请包装 bufio.reader 和原始 io.readwritecloser:
// bufferedreadwritecloser has all of the methods // from *bufio.reader and io.readwritecloser. type bufferedreadwritecloser struct { *bufio.reader io.readwritecloser } func (rw *bufferedreadwritecloser) read(p []byte) (int, error) { return rw.reader.read(p) }
使用方法如下:
rw := &BufferedReadWriteCloser{bufio.NewReader(i), i} p, err := rw.Peek(1)
rw的值满足io.readwritecloser接口。
不要求或假设 io.readwritecloser 具有 seek 方法。
以上就是从 `bufio.Reader` 转换为 `io.ReadWriteCloser`的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号