主機字節序
主機字節序模式有兩種,大端數據模式和小端數據模式,在網絡編程中應注意這兩者的區別,以保證數據處理的正確性;例如網絡的數據是以大端數據模式進行交互,而我們的主機大多數以小端模式處理,如果不轉換,數據會混亂 參考 ;一般來說,兩個主機在網絡通信需要經過如下轉換過程:主機字節序 —> 網絡字節序 -> 主機字節序
大端小端區別
大端模式:Big-Endian就是高位字節排放在內存的低地址端,低位字節排放在內存的高地址端
低地址 --------------------> 高地址
高位字節 地位字節
小端模式:Little-Endian就是低位字節排放在內存的低地址端,高位字節排放在內存的高地址端
低地址 --------------------> 高地址
低位字節 高位字節
什么是高位字節和低位字節
例如在32位系統中,357轉換成二級制為:00000000 00000000 00000001 01100101,其中
00000001 | 01100101
高位字節 低位字節
int和byte轉換
在go語言中,byte其實是uint8的別名,byte 和 uint8 之間可以直接進行互轉。目前來只能將0~255范圍的int轉成byte。因為超出這個范圍,go在轉換的時候,就會把多出來數據扔掉;如果需要將int32轉成byte類型,我們只需要一個長度為4的[]byte數組就可以了
大端模式下
func f2() {
var v2 uint32
var b2 [4]byte
v2 = 257
// 將 257轉成二進制就是
// | 00000000 | 00000000 | 00000001 | 00000001 |
// | b2[0] | b2[1] | b2[2] | b2[3] | // 這里表示b2數組每個下標里面存放的值
// 這里直接使用將uint32強轉成uint8
// | 00000000 0000000 00000001 | 00000001 直接轉成uint8后等于 1
// |---這部分go在強轉的時候扔掉---|
b2[3] = uint8(v2)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移8位 轉成uint8后等于 1
// 下面是右移后的數據
// | | 00000000 | 00000000 | 00000001 |
b2[2] = uint8(v2 >> 8)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移16位 轉成uint8后等于 0
// 下面是右移后的數據
// | | | 00000000 | 00000000 |
b2[1] = uint8(v2 >> 16)
// | 00000000 | 00000000 | 00000001 | 00000001 | 右移24位 轉成uint8后等于 0
// 下面是右移后的數據
// | | | | 00000000 |
b2[0] = uint8(v2 >> 24)
fmt.Printf("%+v\n", b2)
// 所以最終將uint32轉成[]byte數組輸出為
// [0 0 1 1]
}
小端模式下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
// 在上面我們講過,小端剛好和大端相反的,所以在轉成小端模式的時候,只要將[]byte數組的下標首尾對換一下位置就可以了 func f3() { var v3 uint32 var b3 [4]byte v3 = 257 // 將 256轉成二進制就是 // | 00000000 | 00000000 | 00000001 | 00000001 | // | b3[0] | b3[1] | b3[2] | [3] | // 這里表示b3數組每個下標里面存放的值 // 這里直接使用將uint32l強轉成uint8 // | 00000000 0000000 00000001 | 00000001 直接轉成uint8后等于 1 // |---這部分go在強轉的時候扔掉---| b3[0] = uint8(v3) // | 00000000 | 00000000 | 00000001 | 00000001 | 右移8位 轉成uint8后等于 1 // 下面是右移后的數據 // | | 00000000 | 00000000 | 00000001 | b3[1] = uint8(v3 >> 8) // | 00000000 | 00000000 | 00000001 | 00000001 | 右移16位 轉成uint8后等于 0 // 下面是右移后的數據 // | | | 00000000 | 00000000 | b3[2] = uint8(v3 >> 16) // | 00000000 | 00000000 | 00000001 | 00000001 | 右移24位 轉成uint8后等于 0 // 下面是右移后的數據 // | | | | 00000000 | b3[3] = uint8(v3 >> 24) fmt .Printf( "%+v\n" , b3) // 所以最終將uint32轉成[]byte數組輸出為 // [1 1 0 0 ] } |
go轉換demo
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
// 整形轉換成字節 func IntToBytes(n int) []byte { x := int32(n) bytesBuffer := bytes.NewBuffer([]byte{}) binary.Write(bytesBuffer, binary.BigEndian, x) return bytesBuffer.Bytes() } // 字節轉換成整形 func BytesToInt(b []byte) int { bytesBuffer := bytes.NewBuffer(b) var x int32 binary.Read(bytesBuffer, binary.BigEndian, &x) return int(x) } |
總結
以上所述是小編給大家介紹的go語言中int和byte轉換方式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
原文鏈接:https://studygolang.com/articles/16154