今天我们继续讲golang标准库的os包,依然是没有废话直接来

(1)(f File).Name()这个函数是返回文件的名称,函数原型func (f File) Name() string要文件的指针操作,返回字符串,感觉比较鸡助的方法底层实现

  1. func (f *File) Name() string { return f.name }
  2. import (
  3. "fmt"
  4. "os"
  5. )
  6. func main() {
  7. f, _ := os.Open("1.go")
  8. fmt.Println(f.Name()) //输出1.go
  9. }

(2)(f File).Read()这个是函数的指针来操作的,属于FIlE的method,函数原型func (f *File) Read(b []byte) (n int, err error)输入读取的字节数,返回字节的长度和error信息

  1. import (
  2. "fmt"
  3. "os"
  4. )
  5. func main() {
  6. b := make([]byte, 100) //设置读取的字节数
  7. f, _ := os.Open("11.go")
  8. n, _ := f.Read(b)
  9. fmt.Println(n)
  10. fmt.Println(string(b[:n])) //输出内容 为什么是n而不直接输入100呢?底层这样实现的
  11. /*
  12. n, e := f.read(b)
  13. if n < 0 {
  14. n = 0
  15. }
  16. if n == 0 && len(b) > 0 && e == nil {
  17. return 0, io.EOF
  18. }
  19. */
  20. //所以字节不足100就读取n
  21. }

(3)(f File).ReadAt()这个函数的原型是func (f File) ReadAt(b []byte, off int64) (n int, err error)加入了下标,可以自定义读取多少

  1. import (
  2. "fmt"
  3. "os"
  4. )
  5. func main() {
  6. f, _ := os.Open("11.go")
  7. b := make([]byte, 20)
  8. n, _ := f.ReadAt(b, 15)
  9. fmt.Println(n)
  10. fmt.Println(string(b[:n]))
  11. }

(4)(f File).Readdir()函数原型func (f File) Readdir(n int) (fi []FileInfo, err error),我们要打开一个文件夹,然后设置读取文件夹文件的个数,返回的是文件的fileinfo信息

  1. import (
  2. "fmt"
  3. "os"
  4. )
  5. func main() {
  6. f, err := os.Open("src") //打开一个目录
  7. if err != nil {
  8. fmt.Println(err)
  9. }
  10. defer f.Close()
  11. ff, _ := f.Readdir(10) //设置读取的数量 <=0是读取所有的文件 返回的[]fileinfo
  12. for i, fi := range ff {
  13. fmt.Printf("filename %d: %+v\n", i, fi.Name()) //我们输出文件的名称
  14. }
  15. }

(5)(f File).Readdirnames这个函数的作用是读取目录内的文件名,其实上一个函数我们已经实现了这个函数的功能,函数的原型func (f File) Readdirnames(n int) (names []string, err error),跟上边一下只不过返回的是文件名 []string的slice

  1. import (
  2. "fmt"
  3. "os"
  4. )
  5. func main() {
  6. f, _ := os.Open("bin")
  7. names, err := f.Readdirnames(0)
  8. if err != nil {
  9. fmt.Println(err)
  10. }
  11. for i, name := range names {
  12. fmt.Printf("filename %d: %s\n", i, name)
  13. }
  14. }

(6)(f File).Seek()这个函数大家一看就懂了,就是偏移指针的地址,函数的原型是func (f File) Seek(offset int64, whence int) (ret int64, err error) 其中offset是文件指针的位置 whence为0时代表相对文件开始的位置,1代表相对当前位置,2代表相对文件结尾的位置 ret返回的是现在指针的位置

  1. import (
  2. "fmt"
  3. "os"
  4. )
  5. func main() {
  6. b := make([]byte, 10)
  7. f, _ := os.Open("1.go")
  8. defer f.Close()
  9. f.Seek(1, 0) //相当于开始位置偏移1
  10. n, _ := f.Read(b)
  11. fmt.Println(string(b[:n])) //原字符package 输出ackage
  12. }

(7)(f *File).Stat()其中跟前边的os.Stat()一样都是返回Fileinfo所以不多讲了

(8)(f *File).Truncate()这个函数跟前边的os.Truncate()函数是一样的我就不多讲了 大家看os(5)

(9)(f File) Write像文件中写入内容,函数原型func (f File) Write(b []byte) (n int, err error)返回的是n写入的字节数

  1. import (
  2. "fmt"
  3. "os"
  4. )
  5. func main() {
  6. f, _ := os.OpenFile("1.go", os.O_RDWR|os.O_APPEND, 0755) //以追加和读写的方式去打开文件
  7. n, _ := f.Write([]byte("helloword")) //我们写入hellword
  8. fmt.Println(n) //打印写入的字节数
  9. b := make([]byte, 20)
  10. f.Seek(0, 0) //指针返回到0
  11. data, _ := f.Read(b)
  12. fmt.Println(string(b[:data])) //输出了packagehelloword
  13. }

(10)(f File) WriteAt()在偏移位置多少的地方写入,函数原型是func (f File) WriteAt(b []byte, off int64) (n int, err error)返回值是一样的

  1. import (
  2. "fmt"
  3. "os"
  4. )
  5. func main() {
  6. f, _ := os.OpenFile("1.go", os.O_RDWR, os.ModePerm)
  7. f.WriteAt([]byte("widuu"), 10) //在偏移10的地方写入
  8. b := make([]byte, 20)
  9. d, _ := f.ReadAt(b, 10) //偏移10的地方开始读取
  10. fmt.Println(string(b[:d])) //widuudhellowordhello
  11. }

(11)(f File).WriteString()这个很简单了,写入字符串函数原型func (f File) WriteString(s string) (ret int, err error)返回值一样的了

  1. import (
  2. "fmt"
  3. "os"
  4. )
  5. func main() {
  6. f, _ := os.OpenFile("2.go", os.O_RDWR, os.ModePerm)
  7. n, _ := f.WriteString("hello word widuu") //写入字符串
  8. fmt.Println(n)
  9. b := make([]byte, n)
  10. f.Seek(0, 0) //一定要把偏移地址归0否则就一直在写入的结尾处
  11. c, _ := f.Read(b)
  12. fmt.Println(string(b[:c])) //返回hello word widuu
  13. }

好了今天我们就讲完这些,明天我们继续讲os包