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时,需要按照大端编码