• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

go binary 大端小端理解

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
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

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

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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap