golang中的io.ReadCloser与ioutil.NopCloser使用

2024-04-18 0 225
目录

io.ReadCloser与ioutil.NopCloser使用

type ReadCloser interface {
Reader
Closer
}

type nopCloser struct {
io.Reader
}

func (nopCloser) Close() error { return nil }

// NopCloser returns a ReadCloser with a no-op Close method wrapping
// the provided Reader r.
func NopCloser(r io.Reader) io.ReadCloser {
return nopCloser{r}
}

ioutil.NopCloser返回一个 io.ReadCloser,并且 close()方法没有任何操作 no-op。

我们在操作req *http.Request和response *http.Response的时候,有时候需要读取Body,但是读了之后Body里面就被清空了,因此我们需要将读取的内容又重新赋值给Body。

它的类型为io.ReadCloser。

func(response *http.Response) error {
cont, _ := ioutil.ReadAll(response.Body)
fmt.Println(string(cont))

response.Body = ioutil.NopCloser(bytes.NewReader(cont))
return nil
}

golang中的ioutil和log包

  • funcNopCloser

​func NopCloser(r io.Reader) io.ReadCloser​

NopCloser用一个无操作的Close方法包装r返回一个ReadCloser接口。

  • funcReadAll

​func ReadAll(r io.Reader) ([]byte, error)​

ReadAll从r读取数据直到EOF或遇到error,返回读取的数据和遇到的错误。

成功的调用返回的err为nil而非EOF。

因为本函数定义为读取r直到EOF,它不会将读取返回的EOF视为应报告的错误。

  • funcReadFile

​func ReadFile(filename string) ([]byte, error)​

ReadFile从filename指定的文件中读取数据并返回文件的内容。

成功的调用返回的err为nil而非EOF。

因为本函数定义为读取整个文件,它不会将读取返回的EOF视为应报告的错误。

  • funcWriteFile

​func WriteFile(filename string, data []byte, perm os.FileMode) error​

函数向filename指定的文件中写入数据。

如果文件不存在将按给出的权限创建文件,否则在写入数据之前清空文件。

  • funcReadDir

​func ReadDir(dirname string) ([]os.FileInfo, error)​

返回dirname指定的目录的目录信息的有序列表。

  • funcTempDir

​func TempDir(dir, prefix string) (name string, err error)​

在dir目录里创建一个新的、使用prfix作为前缀的临时文件夹,并返回文件夹的路径。

如果dir是空字符串,TempDir使用默认用于临时文件的目录(参见os.TempDir函数)。

不同程序同时调用该函数会创建不同的临时目录,调用本函数的程序有责任在不需要临时文件夹时摧毁它。

  • funcTempFile

​func TempFile(dir, prefix string) (f *os.File, err error)​

在dir目录下创建一个新的、使用prefix为前缀的临时文件,以读写模式打开该文件并返回os.File指针。

如果dir是空字符串,TempFile使用默认用于临时文件的目录(参见os.TempDir函数)。

不同程序同时调用该函数会创建不同的临时文件,调用本函数的程序有责任在不需要临时文件时摧毁它。

  • io func (*PipeReader)Read

​func (r *PipeReader) Read(data []byte) (n int, err error)​

Read实现了标准Reader接口:它从管道中读取数据,会阻塞直到写入端开始写入或写入端被关闭。

  • func (*PipeReader)Close

​func (r *PipeReader) Close() error​

Close关闭读取器;关闭后如果对管道的写入端进行写入操作,就会返回(0, ErrClosedPip)。

  • func (*PipeReader)CloseWithError

​func (r *PipeReader) CloseWithError(err error) error​

CloseWithError类似Close方法,但将调用Write时返回的错误改为err。

  • typePipeWriter

type PipeWriter struct {
// 内含隐藏或非导出字段
}

PipeWriter是一个管道的写入端。

  • func (*PipeWriter)Write

​func (w *PipeWriter) Write(data []byte) (n int, err error)​

Write实现了标准Writer接口:它将数据写入到管道中,会阻塞直到读取器读完所有的数据或读取端被关闭。

  • func (*PipeWriter)Close

​func (w *PipeWriter) Close() error​

Close关闭写入器;关闭后如果对管道的读取端进行读取操作,就会返回(0, EOF)。

  • func (*PipeWriter)CloseWithError

​func (w *PipeWriter) CloseWithError(err error) error​

CloseWithError类似Close方法,但将调用Read时返回的错误改为err。

  • funcTeeReader

​func TeeReader(r Reader, w Writer) Reader​

TeeReader返回一个将其从r读取的数据写入w的Reader接口。

所有通过该接口对r的读取都会执行对应的对w的写入。

没有内部的缓冲:写入必须在读取完成前完成。

写入时遇到的任何错误都会作为读取错误返回。

  • funcMultiReader

​​func TeeReader(r Reader, w Writer) Reader​​

MultiReader返回一个将提供的Reader在逻辑上串联起来的Reader接口。

他们依次被读取。当所有的输入流都读取完毕,Read才会返回EOF。

如果readers中任一个返回了非nil非EOF的错误,Read方法会返回该错误。

  • funcMultiWriter

​func MultiWriter(writers …Writer) Writer​

MultiWriter创建一个Writer接口,会将提供给其的数据写入所有创建时提供的Writer接口。

  • funcCopy

​func Copy(dst Writer, src Reader) (written int64, err error)​

将src的数据拷贝到dst,直到在src上到达EOF或发生错误。

返回拷贝的字节数和遇到的第一个错误。

对成功的调用,返回值err为nil而非EOF,因为Copy定义为从src读取直到EOF,它不会将读取到EOF视为应报告的错误。

如果src实现了WriterTo接口,本函数会调用src.WriteTo(dst)进行拷贝;否则如果dst实现了ReaderFrom接口,本函数会调用dst.ReadFrom(src)进行拷贝。

  • funcCopyN

​func CopyN(dst Writer, src Reader, n int64) (written int64, err error)​

从src拷贝n个字节数据到dst,直到在src上到达EOF或发生错误。

返回复制的字节数和遇到的第一个错误。

只有err为nil时,written才会等于n。

如果dst实现了ReaderFrom接口,本函数很调用它实现拷贝。

  • funcReadAtLeast

​func ReadAtLeast(r Reader, buf []byte, min int) (n int, err error)​

ReadAtLeast从r至少读取min字节数据填充进buf。

函数返回写入的字节数和错误(如果没有读取足够的字节)。

只有没有读取到字节时才可能返回EOF;如果读取了有但不够的字节时遇到了EOF,函数会返回ErrUnexpectedEOF。

如果min比buf的长度还大,函数会返回ErrShortBuffer。

只有返回值err为nil时,返回值n才会不小于min。

  • funcReadFull

​func ReadFull(r Reader, buf []byte) (n int, err error)​

ReadFull从r精确地读取len(buf)字节数据填充进buf。

函数返回写入的字节数和错误(如果没有读取足够的字节)。

只有没有读取到字节时才可能返回EOF;如果读取了有但不够的字节时遇到了EOF,函数会返回ErrUnexpectedEOF。

只有返回值err为nil时,返回值n才会等于len(buf)。

  • funcWriteString

​func WriteString(w Writer, s string) (n int, err error)​

WriteString函数将字符串s的内容写入w中。

如果w已经实现了WriteString方法,函数会直接调用该方法。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持悠久资源网。

您可能感兴趣的文章:

  • Golang语言中fs.ReadDir的全面指南
  • Golang性能提升利器之SectionReader的用法详解
  • golang pprof 监控goroutine thread统计原理详解
  • Golang 使用os 库的 ReadFile() 读文件最佳实践

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 Golang golang中的io.ReadCloser与ioutil.NopCloser使用 https://www.u-9.cn/jiaoben/golang/187401.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务