golang append方法,读文件(buff)

今天研究go的复制文件的时候,发现复制出来的文件老是比源文件大了些,程序以下app

package main

import (
       "os"
       "log"
       "io"
       "fmt"
)

func main() {
       file, err := os.Open("C:/Users/Desktop/123123.txt") // For read access.
       defer file.Close()
       if err != nil {
              log.Fatal(err.Error())
       }

       chunks := make([]byte,1024)
       buff := make([]byte, 1024)
       for{
              count, err := file.Read(buff)
              if err != nil && err != io.EOF{panic(err)}
              if 0==count {break}
              chunks = append(chunks,buff[:count]...)
       }

       file1,err := os.Create("C:/Users/Desktop/123123123.txt")
       defer file1.Close()
       file1.Write(chunks)
}

若是这么写程序的话,会致使复制出来的文件比源文件大1024个字节,为何呢?函数

其实主要是由于go语言的内置函数append的缘由.net

我试验了一下,append函数在将两个切片合在一块儿的时候,并非把第二个切片放进第一个切片里,若是是直接放进去的话,那个切片的长度不会变,以下blog

a:=make([]byte,10)
b:=make([]byte,2)
fmt.Println(len(append(a,b...)))

应该输出10,而其实是输出了12!get

因此,在复制文件的例子中,博客

chunks := make([]byte,1024)应该改成  chunks := make([]byte,0)it

这样,复制出来的文件就是正确的了!io

 

继续补充一点append的用法import

第一种用法,就是第一个参数是切片,后面能够传不少(不固定)元素,好比:file

append([]byte,1,2,3)

第二种用法,就是传两个切片,这样的话,只能传两个参数,且第二个参数要以...结尾,如上面的例子

a:=make([]byte,10)
b:=make([]byte,2)
fmt.Println(len(append(a,b...)))

 

最后,再说一点,读文件时候一些不懂的地方

if err != nil && err != io.EOF{panic(err)}

这一句,涉及两个知识,一个是go语言中的异常,一个是EOF

go语言中的异常机制,有篇博客写的很好,看博客

EOF表示文件结束异常(读完了)

相关文章
相关标签/搜索