go binary 大端小端理解

package main

import (
	"fmt"
	"unsafe"
)
const INT_SIZE int = int(unsafe.Sizeof(0))

func main() {
	systemEdian()
}

func systemEdian() {
	var i int = 0x1234
	bs := (*[INT_SIZE]byte)(unsafe.Pointer(&i))
	fmt.Println(*bs)
	fmt.Println(&bs[0])
	fmt.Println(&bs[1])
	fmt.Println(&bs[2])
	fmt.Println("...")
	if bs[0] == 52 {
		fmt.Println("system edian is little endian")
	} else {
		fmt.Println("system edian is big endian")
	}
}

输出:

[52 18 0 0 0 0 0 0]
0xc000084000
0xc000084001
0xc000084002
...
system edian is little endian

 

52=0x34 18=0x12

低位0x34 存放在低地址0xc000084000

高位0x12 存放在高地址0xc000084001

所以为小端

如果显示为[18 52 0 0 0 0 0 0],则适合人类阅读0x1234,但是不利于计算机计算

 

总结:

大端:高位存放在低地址,低位存放在高地址

小端:高位存放在高地址,低位存放在低地址

 

提问:为什么会有小端字节序?

因为计算机电路先处理低位字节,效率比较高,计算都是从低位开始的,比如45*4,先算低位5*4,再算高位4*4

所以,计算机的内部处理都是小端字节序。

但是,人类还是习惯读写大端字节序。所以,除了计算机的内部处理,其他的场合几乎都是大端字节序,比如网络传输和文件储存。

posted @ 2020-03-10 15:49  lpfuture  阅读(984)  评论(0编辑  收藏  举报