golang复制函数理解
在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是Golang学习者,那么本文《golang复制函数理解》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!
问题内容嘿伙计们,我正在玩一些缓冲区,我刚刚编写了一些代码来了解 read() 的工作原理
package main
import (
"bytes"
"fmt"
"io"
)
func main() {
tmp := make([]byte, 2)
data := []byte("hel")
datareader := bytes.newreader(data)
dest := make([]byte, len(data))
for {
n, err := datareader.read(tmp)
fmt.println(n)
fmt.println(string(tmp))
dest = append(dest, tmp[:]...)
if err == io.eof {
break
}
}
fmt.println(string(dest))
}
output:
2 -> n
HE -> tmp[:]
1 -> n
LE -> tmp[:]
0 -> n
LE -> tmp[:]
HELELE -> dest
所以我知道输出是错误的,我实际上应该执行 temp[:n]
来写入字节,但是查看输出,我意识到 tmp 缓冲区不会在每次迭代时被清除,当 n 为1 缓冲区的内容不应该是 el,我的意思是 l 被添加到 tmp 之前,而不是附加。我查看了 read 函数但无法理解。谁能给我解释一下吗?
解决方案
在第一次迭代中,read
读取两个字节,并且您的程序会生成 he
输出。在第二次迭代中,read
将一个字节读入 tmp
。现在 tmp[0]
包含该字节,但 tmp[1]
仍然包含在第一次迭代期间读取的 e
。但是,您将所有 tmp
附加到 dest
,得到 hele
。第三次,read 读取了 0 个字节,但您仍然将 tmp
中的 tmp
附加到 dest
。
您的程序的正确版本是:
for {
n, err := dataReader.Read(tmp)
fmt.Println(n)
fmt.Println(string(tmp))
dest = append(dest, tmp[:n]...)
if err == io.EOF {
break
}
}
本篇关于《golang复制函数理解》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注编程网公众号!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341