登录
首页 >  Golang >  Go问答

golang的net.conn.read参数如何接收长度未知的数据?

来源:SegmentFault

时间:2023-02-24 15:50:14 438浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《golang的net.conn.read参数如何接收长度未知的数据?》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

问题内容

func (c *IPConn) Read(b []byte) (int, error)

如果我要读取的字节流是未知长度,该怎么办?这里面这个b是不是只能在var声明变量的时候写死长度?

net包它有木有像别的编程语言里面的socket一样以类似于chunk的方式读取?(也就是说从socket缓冲区中每次读小部分数据,直到缓冲区没有数据为止,而不是一次性读整个数据,不然怕大文件会造成卡死)

正确答案

这种需求一般要先定义好包结构,不然就会有沾包问题出现了。基本数据类型(int|bool|byte)可以按照次序pack,对断按照次序读取就好,如果非基本类型,比如string或者binary,可以使用size+data的形式。read时,先读取size,获取之后的data数据长度,再去读取就好了。大体如下:

func (p *BinaryProtocol) ReadBinary() ([]byte, error) {
    size, e := p.ReadI32()
    if e != nil {
        return nil, e
    }
    if size  p.trans.RemainingBytes() {
        return nil, ErrProtocolLen
    }

    isize := int(size)
    buf := make([]byte, isize)
    _, err := io.ReadFull(p.trans, buf)
    return buf, NewBasicExceptionFromError(err)
}

或者很多开发者采用的特殊字符分割的方式,每次读取一个字符,遇到特定字符认为是包截止。

func (p *PacketSample) ReadFull(proto ProtocolIF) error {
    var code int8
    var e error
    var start bool = true

    for code != PacketFlagEnd {
        code, e = proto.ReadByte()
        if e != nil {
            return e
        }
        if start && code != PacketFlagStart {
            return errors.New("Using PacketSample, But not start with " + string(PacketFlagStart))
        }
        // store the byte
        p.WriteByte(code)
        start = false
    }
    return nil
}

理论要掌握,实操不能落!以上关于《golang的net.conn.read参数如何接收长度未知的数据?》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

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