2023-04-28 Go基础——杂项2

msgpack.Marshal序列化之后的大小和原来大小比较

使用 msgpack.Marshal() 函数将数据序列化为 MessagePack 格式之后,通常情况下序列化后的大小会比原始数据的大小更小,因为 MessagePack 格式是一种紧凑的二进制格式,可以有效地压缩数据。

以下是一个示例代码,用于比较序列化之前和之后的数据大小:

import (
    "fmt"
    "github.com/vmihailenco/msgpack/v5"
)

type Person struct {
    Name    string
    Age     int
    Address string
}

func main() {
    p := Person{"Alice", 25, "123 Main St."}
    
    // 序列化之前的数据大小
    fmt.Println("原始数据大小:", len(fmt.Sprintf("%v", p)))
    
    // 序列化之后的数据大小
    b, _ := msgpack.Marshal(p)
    fmt.Println("序列化后数据大小:", len(b))
}

在上面的代码中,我们先定义了一个 Person 结构体,然后分别计算了序列化之前和之后的数据大小。需要注意的是,在使用 msgpack.Marshal() 函数之前需要导入 github.com/vmihailenco/msgpack/v5 包。

在运行上述代码后,我们可以看到序列化之前的数据大小和序列化之后的数据大小。通常情况下,序列化之后的数据大小会比原始数据的大小更小,因为 MessagePack 格式是一种紧凑的二进制格式,可以有效地压缩数据。

conn.SetReadDeadline(time.Now().Add(timeout))

conn.SetReadDeadline(time.Now().Add(timeout)) 是 Go 语言中设置网络连接读取超时时间的一种方式。该方法设置了一个读取超时时间,当连接在该时间内没有收到数据时,读取操作将会超时并返回一个错误。

具体来说,conn 是一个 net.Conn 接口类型的对象,可以是 TCP、UDP 或者其他类型的网络连接。SetReadDeadline 方法会将这个连接的读取超时时间设置为 time.Now().Add(timeout),即当前时间加上 timeout 这个时间段。如果在超时时间内没有收到数据,读取操作将会返回一个超时错误。如果不需要超时限制,可以将 timeout 设置为 0 或者使用 conn.SetReadDeadline(time.Time{}) 来取消读取超时限制。

在网络编程中,设置超时时间可以避免程序无限等待数据的情况,从而提高程序的健壮性和性能。

binary.BigEndian.Uint16(data[i:])

binary.BigEndian.Uint16(data[i:]) 是 Go 语言中将一个 2 字节的大端序字节切片转换为 uint16 类型的方法。其中,data 是一个字节切片,i 是一个整数参数,表示字节切片的起始位置。

具体来说,binary.BigEndian.Uint16 函数会将 data[i:i+2] 这个字节切片解释为一个大端序的无符号 16 位整数,并将其转换为 uint16 类型返回。在大端序中,高位字节存储在低地址处,低位字节存储在高地址处。因此,在将字节切片转换为整数时,需要根据字节序进行解析。

这个方法通常用于将网络数据中的二进制数据转换为整数类型。例如,在读取网络数据时,可以使用这个方法将接收到的字节切片转换为整数类型,以便进一步处理和解析数据。

需要注意的是,如果字节切片的长度小于 2,或者 i+2 超出了字节切片的范围,这个方法将会产生一个运行时错误。在使用这个方法时,需要确保字节切片的长度和起始位置是有效的。

posted @ 2024-03-10 01:36  lovevivi121  阅读(11)  评论(0)    收藏  举报  来源