io/ioutil包

作者: ljh123 | 来源:发表于2018-09-12 23:04 被阅读12次

    ioutil包提供给外部使用的一共有1个变量,7个方法。
    其中变量Discard是io.Write接口类型,调用该变量的Write方法不会做任何事情,并且是以成功的方式返回。
    它的原型是:var Discard io.Write = devNull(0)

    7个方法中有两个函数是直接针对文件读操作和写操作的:
    (1)ReadFile
    原型:func ReadFile(filename string) ([]byte, error)
    ReadFile读取文件中的所有数据,返回读取的内容和遇到的错误。
    (2)WriteFile
    原型:func WriteFile(filename string, data []byte, perm os.FileMode) error
    WriteFile向文件写入数据,如果之前有数据则会将原来的进行清空,如果文件不存在则会以指定的权限创建该文件。

    然后有一个函数是对目录进行读操作:
    (3)ReadDir
    原型:func ReadDir(dirname string) ([]os.FileInfo, error)
    ReadDir读取指定目录中的所有目录和文件(不包括子目录)。返回读取的文件信息列表和遇到的错误,列表是经过排序的。

    之后有两个是临时对文件目录操作的函数:
    (4)TempFile
    原型:func TempFile(dir, prefix string) (f *os.File, err error)
    TempFile在dir目录中创建一个以prefix为前缀的临时文件,并将其以读写模式打开。返回创建的文件对象和遇到的错误信息。如果dir为空,则在默认的临时目录中创建文件(参见os.TimeDir),多次调用会创建不同的临时文件,调用者可以通过f.Name()获取文件的完整路径。调用本函数所创建的临时文件,应该由调用者自己删除。
    (5)TempDir
    原型:func TempDir(dir, prefix string) (name string, err error)
    TempDir功能是创建临时目录(其他功能和TempFile一样),返回创建的完整的目录和遇到的错误信息。

    之后是一个对实现了io.Reader接口的使用:
    (6)ReadAll
    原型:func ReadAll(r io.Reader) ([]byte, error)
    ReadFile读取文件中的所有数据,返回读取的数据和遇到的错误。如果读取成功,则err返回nil,而不是EOF。

    最后一个是NopCloser:
    (7)NopCloser
    原型:func NopCloser(r io.Reader) io.ReadCloser
    NopCloser将r包装为一个ReadCloser类型,但Close方法不做任何事情。

    关于go标准库的io/ioutil包可以参考:http://www.cnblogs.com/golove/p/3278444.html

    相关文章

      网友评论

        本文标题:io/ioutil包

        本文链接:https://www.haomeiwen.com/subject/klcigftx.html