原文:https://blog.csdn.net/whatday/article/details/103938124
读文件
读取的文件放在file/test:也就是file包下的test这个文件,里面写多一点文件
读文件方式一:利用ioutil.ReadFile直接从文件读取到[]byte中
- func Read0() (string){
- f, err := ioutil.ReadFile("file/test")
- if err != nil {
- fmt.Println("read fail", err)
- }
- return string(f)
- }
读文件方式二:先从文件读取到file中,在从file读取到buf, buf在追加到最终的[]byte
- func Read1() (string){
- //获得一个file
- f, err := os.Open("file/test")
- if err != nil {
- fmt.Println("read fail")
- return ""
- }
- //把file读取到缓冲区中
- defer f.Close()
- var chunk []byte
- buf := make([]byte, 1024)
- for {
- //从file读取到buf中
- n, err := f.Read(buf)
- if err != nil && err != io.EOF{
- fmt.Println("read buf fail", err)
- return ""
- }
- //说明读取结束
- if n == 0 {
- break
- }
- //读取到最终的缓冲区中
- chunk = append(chunk, buf[:n]...)
- }
- return string(chunk)
- //fmt.Println(string(chunk))
- }
读文件方式三:先从文件读取到file, 在从file读取到Reader中,从Reader读取到buf, buf最终追加到[]byte
- //先从文件读取到file, 在从file读取到Reader中,从Reader读取到buf, buf最终追加到[]byte,这个排第三
- func Read2() (string) {
- fi, err := os.Open("file/test")
- if err != nil {
- panic(err)
- }
- defer fi.Close()
- r := bufio.NewReader(fi)
- var chunks []byte
- buf := make([]byte, 1024)
- for {
- n, err := r.Read(buf)
- if err != nil && err != io.EOF {
- panic(err)
- }
- if 0 == n {
- break
- }
- //fmt.Println(string(buf))
- chunks = append(chunks, buf...)
- }
- return string(chunks)
- //fmt.Println(string(chunks))
- }
读文件方式四:读取到file中,再利用ioutil将file直接读取到[]byte中
- //读取到file中,再利用ioutil将file直接读取到[]byte中, 这是最优
- func Read3() (string){
- f, err := os.Open("file/test")
- if err != nil {
- fmt.Println("read file fail", err)
- return ""
- }
- defer f.Close()
- fd, err := ioutil.ReadAll(f)
- if err != nil {
- fmt.Println("read to fd fail", err)
- return ""
- }
- return string(fd)
- }
读取速度比较
- import (
- "bufio"
- "fmt"
- "io"
- "io/ioutil"
- "os"
- "time"
- )
- func Read1() string {
- f, err := ioutil.ReadFile("/root/test")
- if err != nil {
- fmt.Println("read fail", err)
- }
- return string(f)
- }
- func Read2() string {
- //获得一个file
- f, err := os.Open("/root/test")
- if err != nil {
- fmt.Println("read fail")
- return ""
- }
- //把file读取到缓冲区中
- defer f.Close()
- var chunk []byte
- buf := make([]byte, 1024)
- for {
- //从file读取到buf中
- n, err := f.Read(buf)
- if err != nil && err != io.EOF {
- fmt.Println("read buf fail", err)
- return ""
- }
- //说明读取结束
- if n == 0 {
- break
- }
- //读取到最终的缓冲区中
- chunk = append(chunk, buf[:n]...)
- }
- return string(chunk)
- //fmt.Println(string(chunk))
- }
- func Read3() string {
- fi, err := os.Open("/root/test")
- if err != nil {
- panic(err)
- }
- defer fi.Close()
- r := bufio.NewReader(fi)
- var chunks []byte
- buf := make([]byte, 1024)
- for {
- n, err := r.Read(buf)
- if err != nil && err != io.EOF {
- panic(err)
- }
- if 0 == n {
- break
- }
- //fmt.Println(string(buf))
- chunks = append(chunks, buf...)
- }
- return string(chunks)
- //fmt.Println(string(chunks))
- }
- func Read4() string {
- f, err := os.Open("/root/test")
- if err != nil {
- fmt.Println("read file fail", err)
- return ""
- }
- defer f.Close()
- fd, err := ioutil.ReadAll(f)
- if err != nil {
- fmt.Println("read to fd fail", err)
- return ""
- }
- return string(fd)
- }
- func main() {
- start := time.Now().UnixNano() / 1e6
- Read1()
- end := time.Now().UnixNano() / 1e6
- fmt.Printf("Read1=%d,\n", end-start)
- }
分别测试 read2 read3 read4
- func main() {
- start := time.Now().UnixNano() / 1e6
- Read2()
- end := time.Now().UnixNano() / 1e6
- fmt.Printf("Read2=%d,\n", end-start)
- }
- func main() {
- start := time.Now().UnixNano() / 1e6
- Read3()
- end := time.Now().UnixNano() / 1e6
- fmt.Printf("Read3=%d,\n", end-start)
- }
- func main() {
- start := time.Now().UnixNano() / 1e6
- Read4()
- end := time.Now().UnixNano() / 1e6
- fmt.Printf("Read4=%d,\n", end-start)
- }
输出结果
- [root@localhost src]# ll -h /root | grep test
- -rwxr-xr-x. 1 root root 136M Nov 7 19:20 test
- [root@localhost src]# go build
- [root@localhost src]# ./test
- Read1=625,
- [root@localhost src]# go build
- [root@localhost src]# ./test
- Read2=1313,
- [root@localhost src]# go build
- [root@localhost src]# ./test
- Read3=1724,
- [root@localhost src]# go build
- [root@localhost src]# ./test
- Read4=1057,
经过测试,这四种方式读的速度排名是:前者为优
方式一 > 方式四 > 方式二 > 方式三
写文件
写文件方式一:使用 io.WriteString 写入文件
- func Write0() {
- fileName := "file/test1"
- strTest := "测试测试"
- var f *os.File
- var err error
- if CheckFileExist(fileName) { //文件存在
- f, err = os.OpenFile(fileName, os.O_APPEND, 0666) //打开文件
- if err != nil{
- fmt.Println("file open fail", err)
- return
- }
- }else { //文件不存在
- f, err = os.Create(fileName) //创建文件
- if err != nil {
- fmt.Println("file create fail")
- return
- }
- }
- //将文件写进去
- n, err1 := io.WriteString(f, strTest)
- if err1 != nil {
- fmt.Println("write error", err1)
- return
- }
- fmt.Println("写入的字节数是:", n)
- }
写文件方式二:使用 ioutil.WriteFile 写入文件
- func Write1() {
- fileName := "file/test2"
- strTest := "测试测试"
- var d = []byte(strTest)
- err := ioutil.WriteFile(fileName, d, 0666)
- if err != nil {
- fmt.Println("write fail")
- }
- fmt.Println("write success")
- }
写文件方式三:使用 File(Write,WriteString) 写入文件
- func Write2() {
- fileName := "file/test3"
- strTest := "测试测试"
- var d1 = []byte(strTest)
- f, err3 := os.Create(fileName) //创建文件
- if err3 != nil{
- fmt.Println("create file fail")
- }
- defer f.Close()
- n2, err3 := f.Write(d1) //写入文件(字节数组)
- fmt.Printf("写入 %d 个字节n", n2)
- n3, err3 := f.WriteString("writesn") //写入文件(字节数组)
- fmt.Printf("写入 %d 个字节n", n3)
- f.Sync()
- }
写文件方式四:使用 bufio.NewWriter 写入文件
- func Write3() {
- fileName := "file/test3"
- f, err3 := os.Create(fileName) //创建文件
- if err3 != nil{
- fmt.Println("create file fail")
- }
- w := bufio.NewWriter(f) //创建新的 Writer 对象
- n4, err3 := w.WriteString("bufferedn")
- fmt.Printf("写入 %d 个字节n", n4)
- w.Flush()
- f.Close()
- }
检查文件是否存在:
- func CheckFileExist(fileName string) bool {
- _, err := os.Stat(fileName)
- if os.IsNotExist(err) {
- return false
- }
- return true
- }