主機字節(jié)序
主機字節(jié)序模式有兩種,大端數(shù)據(jù)模式和小端數(shù)據(jù)模式,在網(wǎng)絡(luò)編程中應(yīng)注意這兩者的區(qū)別,以保證數(shù)據(jù)處理的正確性;例如網(wǎng)絡(luò)的數(shù)據(jù)是以大端數(shù)據(jù)模式進行交互,而我們的主機大多數(shù)以小端模式處理,如果不轉(zhuǎn)換,數(shù)據(jù)會混亂 參考 ;一般來說,兩個主機在網(wǎng)絡(luò)通信需要經(jīng)過如下轉(zhuǎn)換過程:主機字節(jié)序 —> 網(wǎng)絡(luò)字節(jié)序 -> 主機字節(jié)序
大端小端區(qū)別
大端模式:Big-Endian就是高位字節(jié)排放在內(nèi)存的低地址端,低位字節(jié)排放在內(nèi)存的高地址端
低地址 --------------------> 高地址
高位字節(jié) 地位字節(jié)
小端模式:Little-Endian就是低位字節(jié)排放在內(nèi)存的低地址端,高位字節(jié)排放在內(nèi)存的高地址端
低地址 --------------------> 高地址
低位字節(jié) 高位字節(jié)
什么是高位字節(jié)和低位字節(jié)
例如在32位系統(tǒng)中,357轉(zhuǎn)換成二級制為:00000000 00000000 00000001 01100101,其中
00000001 | 01100101
高位字節(jié) 低位字節(jié)
int和byte轉(zhuǎn)換
在go語言中,byte其實是uint8的別名,byte 和 uint8 之間可以直接進行互轉(zhuǎn)。目前來只能將0~255范圍的int轉(zhuǎn)成byte。因為超出這個范圍,go在轉(zhuǎn)換的時候,就會把多出來數(shù)據(jù)扔掉;如果需要將int32轉(zhuǎn)成byte類型,我們只需要一個長度為4的[]byte數(shù)組就可以了
大端模式下
func f2() {
var v2 uint32
var b2 [4]byte
v2 = 257
// 將 257轉(zhuǎn)成二進制就是
// | 00000000 | 00000000 | 00000001 | 00000001 |
// | b2[0] | b2[1] | b2[2] | b2[3] | // 這里表示b2數(shù)組每個下標里面存放的值
// 這里直接使用將uint32強轉(zhuǎn)成uint8
// | 00000000 0000000 00000001 | 00000001 直接轉(zhuǎn)成uint8后等于 1
// |---這部分go在強轉(zhuǎn)的時候扔掉---|
b2[3] = uint8(v2)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移8位 轉(zhuǎn)成uint8后等于 1
// 下面是右移后的數(shù)據(jù)
// | | 00000000 | 00000000 | 00000001 |
b2[2] = uint8(v2 >> 8)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移16位 轉(zhuǎn)成uint8后等于 0
// 下面是右移后的數(shù)據(jù)
// | | | 00000000 | 00000000 |
b2[1] = uint8(v2 >> 16)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移24位 轉(zhuǎn)成uint8后等于 0
// 下面是右移后的數(shù)據(jù)
// | | | | 00000000 |
b2[0] = uint8(v2 >> 24)
fmt.Printf("%+v\n", b2)
// 所以最終將uint32轉(zhuǎn)成[]byte數(shù)組輸出為
// [0 0 1 1]
}
小端模式下
// 在上面我們講過,小端剛好和大端相反的,所以在轉(zhuǎn)成小端模式的時候,只要將[]byte數(shù)組的下標首尾對換一下位置就可以了
func f3() {
var v3 uint32
var b3 [4]byte
v3 = 257
// 將 256轉(zhuǎn)成二進制就是
// | 00000000 | 00000000 | 00000001 | 00000001 |
// | b3[0] | b3[1] | b3[2] | [3] | // 這里表示b3數(shù)組每個下標里面存放的值
// 這里直接使用將uint32l強轉(zhuǎn)成uint8
// | 00000000 0000000 00000001 | 00000001 直接轉(zhuǎn)成uint8后等于 1
// |---這部分go在強轉(zhuǎn)的時候扔掉---|
b3[0] = uint8(v3)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移8位 轉(zhuǎn)成uint8后等于 1
// 下面是右移后的數(shù)據(jù)
// | | 00000000 | 00000000 | 00000001 |
b3[1] = uint8(v3 >> 8)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移16位 轉(zhuǎn)成uint8后等于 0
// 下面是右移后的數(shù)據(jù)
// | | | 00000000 | 00000000 |
b3[2] = uint8(v3 >> 16)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移24位 轉(zhuǎn)成uint8后等于 0
// 下面是右移后的數(shù)據(jù)
// | | | | 00000000 |
b3[3] = uint8(v3 >> 24)
fmt.Printf("%+v\n", b3)
// 所以最終將uint32轉(zhuǎn)成[]byte數(shù)組輸出為
// [1 1 0 0 ]
}
go轉(zhuǎn)換demo
//整形轉(zhuǎn)換成字節(jié)
func IntToBytes(n int) []byte {
x := int32(n)
bytesBuffer := bytes.NewBuffer([]byte{})
binary.Write(bytesBuffer, binary.BigEndian, x)
return bytesBuffer.Bytes()
}
//字節(jié)轉(zhuǎn)換成整形
func BytesToInt(b []byte) int {
bytesBuffer := bytes.NewBuffer(b)
var x int32
binary.Read(bytesBuffer, binary.BigEndian, x)
return int(x)
}
總結(jié)
以上所述是小編給大家介紹的go語言中int和byte轉(zhuǎn)換方式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
您可能感興趣的文章:- Go語言string,int,int64 ,float之間類型轉(zhuǎn)換方法
- golang實現(xiàn)整型和字節(jié)數(shù)組之間的轉(zhuǎn)換操作
- golang int 轉(zhuǎn)float 強轉(zhuǎn)和高精度轉(zhuǎn)操作