zl程序教程

您现在的位置是:首页 >  后端

当前栏目

Go语言使用切片读写文件

Go文件语言 使用 读写 切片
2023-06-13 09:12:00 时间
切片提供了 Go语言中处理 I/O 缓冲的标准方式,下面 cat 函数的第二版中,在一个切片缓冲内使用无限 for 循环(直到文件尾部 EOF)读取文件,并写入到标准输出(os.Stdout)。


func cat(f *os.File) {

 const NBUF = 512

 var buf [NBUF]byte

 for {

 switch nr, err := f.Read(buf[:]); true {

 case nr 0:

 fmt.Fprintf(os.Stderr, cat: error reading: %s/n , err.Error())

 os.Exit(1)

 case nr == 0: // EOF

 return

 case nr 0:

 if nw, ew := os.Stdout.Write(buf[0:nr]); nw != nr {

 fmt.Fprintf(os.Stderr, cat: error writing: %s/n , ew.Error())

}

下面的代码使用了 os 包中的 os.file 和 Read 方法;与上一节示例代码具有同样的功能。


package main

import (

 flag 

 fmt 

func cat(f *os.File) {

 const NBUF = 512

 var buf [NBUF]byte

 for {

 switch nr, err := f.Read(buf[:]); true {

 case nr 0:

 fmt.Fprintf(os.Stderr, cat: error reading: %s/n , err.Error())

 os.Exit(1)

 case nr == 0: // EOF

 return

 case nr 0:

 if nw, ew := os.Stdout.Write(buf[0:nr]); nw != nr {

 fmt.Fprintf(os.Stderr, cat: error writing: %s/n , ew.Error())

func main() {

 flag.Parse() // 扫描arg列表并设置标志

 if flag.NArg() == 0 {

 cat(os.Stdin)

 for i := 0; i flag.NArg(); i++ {

 f, err := os.Open(flag.Arg(i))

 if f == nil {

 fmt.Fprintf(os.Stderr, cat: can t open %s: error %s/n , flag.Arg(i), err)

 os.Exit(1)

 cat(f)

 f.Close()

}

22605.html

go