golang append方法,读文件(buff)
程序羊 · · 2816 次点击 · · 开始浏览今天研究go的复制文件的时候,发现复制出来的文件总是比源文件大了些,程序如下
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的原因
我试验了一下,append函数在将两个切片合在一起的时候,并不是把第二个切片放进第一个切片里,如果是直接放进去的话,那个切片的长度不会变,如下
a:=make([]byte,10) b:=make([]byte,2) fmt.Println(len(append(a,b...)))
应该输出10,而实际上是输出了12!
所以,在复制文件的例子中,
chunks := make([]byte,1024)应该改为 chunks := make([]byte,0)
这样,复制出来的文件就是正确的了!
继续补充一点append的用法
第一种用法,就是第一个参数是切片,后面可以传很多(不固定)元素,比如:
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表示文件结束异常(读完了)
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
今天研究go的复制文件的时候,发现复制出来的文件总是比源文件大了些,程序如下
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的原因
我试验了一下,append函数在将两个切片合在一起的时候,并不是把第二个切片放进第一个切片里,如果是直接放进去的话,那个切片的长度不会变,如下
a:=make([]byte,10) b:=make([]byte,2) fmt.Println(len(append(a,b...)))
应该输出10,而实际上是输出了12!
所以,在复制文件的例子中,
chunks := make([]byte,1024)应该改为 chunks := make([]byte,0)
这样,复制出来的文件就是正确的了!
继续补充一点append的用法
第一种用法,就是第一个参数是切片,后面可以传很多(不固定)元素,比如:
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表示文件结束异常(读完了)