go语言判断大小端 golang判断字符串相等

Go语言中的字节序Go中的binary包实现了简单的数字与字节序列的转换以及变长值的编解码
package main
import ( "fmt" "bytes" "encoding/binary" ) func main(){ n := 0x12345678 bytesBuffer := bytes.NewBuffer([]byte{}) //BigEndian 大端顺序存储 LittleEndian小端顺序存储 binary.Write(bytesBuffer, binary.BigEndian, int32(n)) data:=bytesBuffer.Bytes() fmt.Printf("[0]: %#x addr:%#x\n",data[0],data[0]) fmt.Printf("[0]: %#x addr:%#x\n",data[1],data[1]) fmt.Printf("[0]: %#x addr:%#x\n",data[2],data[2]) fmt.Printf("[0]: %#x addr:%#x\n",data[3],data[3]) }
输出
[0]: 0x12 addr:0xc042010248 [1]: 0x34 addr:0xc042010249 [2]: 0x56 addr:0xc04201024a [3]: 0x78 addr:0xc04201024b
也可以使用下面的方式
n := 0x12345678 var data []byte = make([]byte,4) //操作的都是无符号整型 binary.BigEndian.PutUint32(data,uint32(n))
可以使用下面的方式判断当前系统的字节序类型
const INT_SIZE int = int(unsafe.Sizeof(0))
//判断我们系统中的字节序类型 func systemEdian() { var i int = 0x1 bs := (*[INT_SIZE]byte)(unsafe.Pointer(i)) if bs[0] == 0 { fmt.Println("system edian is little endian") } else { fmt.Println("system edian is big endian") } }
golang之大端序、小端序当分别处于大小端模式下的内容存放如下
(1)大端模式存储(存储地址为16位)
地址数据
0x0004(高地址)0x44
0x00030x33
0x00020x22
0x0001(低地址)0x11
(2)小端模式存储(存储地址为16位)
地址数据
0x0004(高地址)0x11
0x00030x22
0x00020x33
0x0001(低地址)0x44
在前面也简单阐述了大小端序的定义并结合简单实例来说明,接下来会给出详细实例来说明:
1、大端序(Big-Endian):或称大尾序
一个类型: int32 的数 0X0A0B0C0D的内存存放情况
数据是以8bits为单位
2、小端序(little-endian):或称小尾序
比如0x00000001
大端序:内存低比特位 00000000 00000000 00000000 00000001 内存高比特位
小端序:内存低比特位 10000000 00000000 00000000 00000000 内存高比特位
其实在前面罗列出那么东西,最终是为了接下来讲述的在golang中涉及到网络传输、文件存储时的选择 。一般来说网络传输的字节序,可能是大端序或者小端序,取决于软件开始时通讯双方的协议规定 。TCP/IP协议RFC1700规定使用“大端”字节序为网络字节序,开发的时候需要遵守这一规则 。默认golang是使用大端序 。详情见golang中包encoding/binary已提供了大、小端序的使用
输出结果:
16909060 use big endian:
【go语言判断大小端 golang判断字符串相等】int32 to bytes: [1 2 3 4]### [0001 0002 0003 0004]
bytes to int32: 16909060
16909060 use little endian:
int32 to bytes: [4 3 2 1]### [0004 0003 0002 0001]
bytes to int32: 16909060
在RPCX框架中关于RPC调用过程涉及的传递消息进行编码的,采用的就是大端序模式
golang保存二进制文件会有大小端问题吗golang保存二进制文件会有大小端问题 。
这个二进制文件go语言判断大小端的确有Big Endian 和Little Endian的问题go语言判断大小端 , 这个与CPU指令体系有关,不过不用操心,像JPEG就是Big Endian,其编解码就都是按照这个约定来完成的,没有平台问题,也没有大小端的问题 。
编译centos上的可执行文件的时候需要交叉编译 。golang的交叉编译很容易,go语言判断大小端你的情况的话用下面这条命令,GOOS=linux GOARCH=amd64 go build ./文件 。
golang描述:
Go的语法接近C语言,但对于变量的声明有所不同 。Go支持垃圾回收功能 。Go的并行模型是以东尼·霍尔的通信顺序进程(CSP)为基础 。
采取类似模型的其go语言判断大小端他语言包括Occam和Limbo , 但它也具有Pi运算的特征,比如通道传输 。在1.8版本中开放插件(Plugin)的支持,这意味着现在能从Go中动态加载部分函数 。

推荐阅读