登录
首页 >  Golang >  Go问答

golang复制函数理解

来源:stackoverflow

时间:2024-04-04 17:09:31 196浏览 收藏

在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的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>