我有一个 io.readwritecloser
,我想在不推进读者的情况下窥视它,
所以我正在使用
bi := bufio.NewReader(i) bi.Peek(1)
到目前为止一切顺利,但后来当我想重用原始的 io.readwritecloser
(i
) 时,它只有 eof
(i
) 时,它只有 eof
。
所以我的问题是如何从 bufio.reader
转换回 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中文网其他相关文章!