------------------------------------------------------------ // Discard 是一个 io.Writer 接口,调用它的 Write 方法将不作任何事情 // 而且始终成功返回。 var Discard io.Writer = devNull(0) // ReadAll 读取 r 中的全部数据,返回读取的数据和遇到的错误。 // 若是读取成功,则 err 返回 nil,而不是 EOF,由于 ReadAll 定义为读取 // 全部数据,因此不会把 EOF 当作错误处理。 func ReadAll(r io.Reader) ([]byte, error) // ReadFile 读取文件中的全部数据,返回读取的数据和遇到的错误。 // 若是读取成功,则 err 返回 nil,而不是 EOF func ReadFile(filename string) ([]byte, error) // WriteFile 向文件中写入数据,写入前会清空文件。 // 若是文件不存在,则会以指定的权限建立该文件。 // 返回遇到的错误。 func WriteFile(filename string, data []byte, perm os.FileMode) error // ReadDir 读取指定目录中的全部目录和文件(不包括子目录)。 // 返回读取到的文件信息列表和遇到的错误,列表是通过排序的。 func ReadDir(dirname string) ([]os.FileInfo, error) // NopCloser 将 r 包装为一个 ReadCloser 类型,但 Close 方法不作任何事情。 func NopCloser(r io.Reader) io.ReadCloser // TempFile 在 dir 目录中建立一个以 prefix 为前缀的临时文件,并将其以读 // 写模式打开。返回建立的文件对象和遇到的错误。 // 若是 dir 为空,则在默认的临时目录中建立文件(参见 os.TempDir),屡次 // 调用会建立不一样的临时文件,调用者能够经过 f.Name() 获取文件的完整路径。 // 调用本函数所建立的临时文件,应该由调用者本身删除。 func TempFile(dir, prefix string) (f *os.File, err error) // TempDir 功能同 TempFile,只不过建立的是目录,返回目录的完整路径。 func TempDir(dir, prefix string) (name string, err error) ------------------------------ // 示例:读取目录 func main() { rd, err := ioutil.ReadDir("/") fmt.Println(err) for _, fi := range rd { if fi.IsDir() { fmt.Printf("[%s]\n", fi.Name()) } else { fmt.Println(fi.Name()) } } } ------------------------------ // 示例:临时目录、临时文件 func main() { // 建立临时目录 dir, err := ioutil.TempDir("", "Test") if err != nil { fmt.Println(err) } defer os.Remove(dir) // 用完删除 fmt.Printf("%s\n", dir) // 建立临时文件 f, err := ioutil.TempFile(dir, "Test") if err != nil { fmt.Println(err) } defer os.Remove(f.Name()) // 用完删除 fmt.Printf("%s\n", f.Name()) } ------------------------------------------------------------