golang中io/ioutil包用法

释放双眼,带上耳机,听听看~!

io/ioutil 包中的函数和方法
// ioutil.go

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


1
2
3
4
5
6
7
8
1func main() {
2    s := strings.NewReader("Hello World!")
3    ra, _ := ioutil.ReadAll(s)
4    fmt.Printf("%s", ra)
5    // Hello World!
6}
7
8

1
2
1 ------------------------------------------------------------  
2

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


1
2
3
4
5
1func main() {
2   ra, _ := ioutil.ReadFile("C:\\Windows\\win.ini")
3   fmt.Printf("%s", ra)
4}
5

1
2
1 ------------------------------------------------------------  
2

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


1
2
3
4
5
6
7
8
9
10
1func main() {
2   fn := "C:\\Test.txt"
3   s := []byte("Hello World!")
4   ioutil.WriteFile(fn, s, os.ModeAppend)
5   rf, _ := ioutil.ReadFile(fn)
6   fmt.Printf("%s", rf)
7   // Hello World!
8}
9
10

1
2
1 ------------------------------------------------------------  
2

// ReadDir 读取目录 dirmane 中的所有目录和文件(不包括子目录)
// 返回读取到的文件的信息列表和读取过程中遇到的任何错误
// 返回的文件列表是经过排序的
func ReadDir(dirname string) ([]os.FileInfo, error)


1
2
3
4
5
6
7
8
9
10
11
12
13
14
1func main() {
2   rd, err := ioutil.ReadDir("C:\\Windows")
3   for _, fi := range rd {
4       fmt.Println("")
5       fmt.Println(fi.Name())
6       fmt.Println(fi.IsDir())
7       fmt.Println(fi.Size())
8       fmt.Println(fi.ModTime())
9       fmt.Println(fi.Mode())
10  }
11  fmt.Println("")
12  fmt.Println(err)
13}
14


1
2
1var Discard io.Writer = devNull(0)
2

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
1package main
2
3import (
4   "fmt"
5   "io"
6   "io/ioutil"
7   "strings"
8)
9
10func main() {
11  a := strings.NewReader("hello")
12  p := make([]byte, 20)
13  io.Copy(ioutil.Discard, a)
14  ioutil.Discard.Write(p)
15  fmt.Println(p)      //[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
16}
17

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

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


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

// tempfile.go

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


1
2
3
4
5
6
1func main() {
2   dn := "C:\\"
3   f, _ := ioutil.TempFile(dn, "Test")
4   fmt.Printf("%s", f.Name())
5}
6

1
2
1 ------------------------------------------------------------  
2

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


1
2
3
4
5
6
1func main() {
2   dn := "C:\\"
3   f, _ := ioutil.TempDir(dn, "Test")
4   fmt.Printf("%s", f.Name())
5}
6

给TA打赏
共{{data.count}}人
人已打赏
安全技术

C/C++内存泄漏及检测

2022-1-11 12:36:11

安全经验

使用Apriori算法进行关联分析

2021-11-28 16:36:11

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索