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表示文件結束異常(讀完了)

相關文章
相關標籤/搜索