package main
import (
"bytes"
"encoding/binary"
"fmt"
)
// 省略部分代码....
func main() {
//声明两个Writer的实现buffer,长度8,因为长整型int是64位,也就是8字节
littleEndianBuffer := bytes.NewBuffer(make([]byte, 0))
//将变量写入流中 一个使用高字端,一个使用低字端
//write to buffer
err := binary.Write(littleEndianBuffer, binary.BigEndian, uint16(0xaa55))
err = binary.Write(littleEndianBuffer, binary.BigEndian, uint16(0x0002))
if err != nil {
fmt.Println(err)
}
fmt.Printf("len: %d, %x\n", len(littleEndianBuffer.Bytes()), littleEndianBuffer)
for _, b := range littleEndianBuffer.Bytes() {
ptr := &b
value := *ptr //golang 局部变量的坑
fmt.Printf("addr: %p, %x\n", &value, b)
}
fmt.Println("----------------------------------")
data := []byte{0xaa, 0x55, 0x00, 0x02}
fmt.Printf("len:%d, %x", len(data), data)
//[]byte的低字节序在起始处即0xaa
for _, b := range data {
ptr := &b
value := *ptr
fmt.Printf("addr: %p, %x\n", &value, b)
}
}
// continue handling data
所以,整型数插入[]byte时,需要按照大端编码
该代码示例展示了在Golang中如何使用`binary.Write`函数以BigEndian和LittleEndian两种字节序将整型数写入字节缓冲区。文章讨论了整型数在字节序列中的表示,以及在处理字节数据时需要注意的字节序问题。
1577





