golang中io/ioutil包用法

前端之家收集整理的这篇文章主要介绍了golang中io/ioutil包用法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文转自Golove博客http://www.cnblogs.com/golove/p/3278444.html ,并在此基础上进行添加修改

io/IoUtil 包中的函数方法



// IoUtil.go

------------------------------------------------------------

// ReadAll 读取 r 中的所有数据
// 返回读取的数据和读取过程中遇到的任何错误
// 如果读取成功,则 err 返回 nil,而不是 EOF
func ReadAll(r io.Reader) ([]byte,error)

func main() {
 s := strings.NewReader("Hello World!")
 ra,_ := IoUtil.ReadAll(s)
 fmt.Printf("%s",ra)
 // Hello World!
}

------------------------------------------------------------

// ReadFile 读取文件中的所有数据
// 返回读取的数据和读取过程中遇到的任何错误
// 如果读取成功,则 err 返回 nil,而不是 EOF
func ReadFile(filename string) ([]byte,error)

func main() {
	ra,_ := IoUtil.ReadFile("C:\\Windows\\win.ini")
	fmt.Printf("%s",ra)
}

------------------------------------------------------------

// WriteFile 向文件 filename 中写入数据 data
// 如果文件不存在,则以 perm 权限创建该文件
// 如果文件存在,则先清空文件,然后再写入
// 返回写入过程中遇到的任何错误
func WriteFile(filename string,data []byte,perm os.FileMode) error

func main() {
	fn := "C:\\Test.txt"
	s := []byte("Hello World!")
	IoUtil.WriteFile(fn,s,os.ModeAppend)
	rf,_ := IoUtil.ReadFile(fn)
	fmt.Printf("%s",rf)
	// Hello World!
}

------------------------------------------------------------

// ReadDir 读取目录 dirmane 中的所有目录和文件(不包括子目录)
// 返回读取到的文件的信息列表和读取过程中遇到的任何错误
// 返回的文件列表是经过排序的
func ReadDir(dirname string) ([]os.FileInfo,error)
func main() {
	rd,err := IoUtil.ReadDir("C:\\Windows")
	for _,fi := range rd {
		fmt.Println("")
		fmt.Println(fi.Name())
		fmt.Println(fi.IsDir())
		fmt.Println(fi.Size())
		fmt.Println(fi.ModTime())
		fmt.Println(fi.Mode())
	}
	fmt.Println("")
	fmt.Println(err)
}

-----------------------------------------------------------

var Discard io.Writer = devNull(0)
Discard 是一个 io.Writer,对它进行的任何 Write 调用都将无条件成功。devNull优化的实现了ReadFrom,因此io.Copy到IoUtil.Discard避免了不必要的工作,因此其一定会成功.但是IoUtil.Discard不记录copy得到的数值.例子如下:
package main

import (
	"fmt"
	"io"
	"io/IoUtil"
	"strings"
)

func main() {
	a := strings.NewReader("hello")
	p := make([]byte,20)
	io.Copy(IoUtil.Discard,a)
	IoUtil.Discard.Write(p)
	fmt.Println(p)      //[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
}


-----------------------------------------------------------

// NopCloser 将 r 封装为一个 ReadCloser 类型
// 其 Close 方法不做任何事情
func NopCloser(r io.Reader) io.ReadCloser


ReadCloser 接口组合了基本的 Read 和 Close 方法。NopCloser 将提供的 Reader r 用空操作 Close 方法包装后作为 ReadCloser 返回。

func main() {
	s := strings.NewReader("hello world!")
	r := IoUtil.NopCloser(s)
	r.Close()                                  //<span style="color:#FF0000;">此处Close不起作用?!</span>
	p := make([]byte,10)
	r.Read(p)
	fmt.Println(string(p))   //hello worl
}

------------------------------------------------------------

// tempfile.go

------------------------------------------------------------

// TempFile 在目录 dir 中创建一个临时文件并将其打开
// 文件名以 prefix 为前缀
// 返回创建的文件的对象和创建过程中遇到的任何错误
// 如果 dir 为空,则在系统的临时目录中创建临时文件
// 如果环境变量中没有设置系统临时目录,则在 /tmp 中创建临时文件
// 调用者可以通过 f.Name() 方法获取临时文件的完整路径
// 调用 TempFile 所创建的临时文件,应该由调用者自己移除
func TempFile(dir,prefix string) (f *os.File,err error)

func main() {
	dn := "C:\\"
	f,_ := IoUtil.TempFile(dn,"Test")
	fmt.Printf("%s",f.Name())
}

------------------------------------------------------------

// TempDir 功能同 TempFile,只不过创建的是目录
// 返回值也只返目录的完整路径
func TempDir(dir,prefix string) (name string,err error)


func main() {
	dn := "C:\\"
	f,_ := IoUtil.TempDir(dn,f.Name())
}

猜你在找的Go相关文章