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

所以,計算機的內部處理都是小端字節序。

但是,人類還是習慣讀寫大端字節序。所以,除了計算機的內部處理,其他的場合幾乎都是大端字節序,比如網絡傳輸和文件儲存。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM