zoukankan      html  css  js  c++  java
  • 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

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

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

  • 相关阅读:
    AES-GCM算法
    Linux Curl命令
    OpenLDAP
    网络性能测试
    LoadRunner
    XSLT
    dtruss
    删除重复图片
    2018年部门管理的一点总结
    矢量地图方案的进一步探讨
  • 原文地址:https://www.cnblogs.com/lpfuture/p/12456164.html
Copyright © 2011-2022 走看看