在go語言中,byte其實是uint8的別名,byte 和 uint8 之間可以直接進行互轉。
目前來只能將0~255范圍的int轉成byte。
func Int64ToBytes(num int64) []uint8 {
var buffer bytes.Buffer
err := binary.Write(buffer, binary.BigEndian, num)
if err != nil {
logs.Error("int64轉[]uint8失敗%v", err)
}
return buffer.Bytes()
}
在使用binary.Write()的時候,要注意一些問題:
Write writes the binary representation of data into w.
Data must be a fixed-size value or a slice of fixed-size // values, or a pointer to such data.
Boolean values encode as one byte: 1 for true, and 0 for false.
Bytes written to w are encoded using the specified byte order and read from successive fields of the data. When writing structs, zero values are written for fields with blank (_) field names.
我的翻譯是這樣的(本人英文不好,勿怪!)
Write將數據的二進制表示形式寫入w。
數據必須是固定大小的值或固定大小的值的切片,或者是指向此類數據的指針
布爾值編碼為一個字節:1表示true,0表示false。
寫入w的字節使用指定的字節順序進行編碼,并從數據的連續字段中讀取。
寫入結構時,將為空白(_)字段寫入零值名稱。
補充:golang關于json庫的一個比較容易陷入的坑 uint8[]數組的json轉換問題.
類似這個CA如果實例轉化成json.List會變成字符串.
type CA struct {
List []uint8
}
func main() {
ca := CA{[]uint8{1,2,3,4,5,6,7,8,9,0}}
r, _ := json.Marshal(ca)
fmt.Println(string(r)) //{"List":"AQIDBAUGBwgJAA=="}
}
而我們希望的是要一個正常的json. 只有 int8 byte uint8 這種8位的json庫會給我們當成字符串處理.想要解決.如果拍腦袋就不能用這幾種類型了.需要使用16 32 64位的數字才可以正常轉換成json字符串.
{"List":[1,2,3,4,5,6,7,8,9,0]}
但是不用擔心. Unmarshal這個 我們認為不想要的json字符串 重新到CA的其他實例 會得到想要的結果.
如果是跨語言的json通信就要小心了.
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- 手把手教你導入Go語言第三方庫
- golang gopm get -g -v 無法獲取第三方庫的解決方案
- golang 輸出重定向:fmt Log,子進程Log,第三方庫logrus的詳解
- go 類型轉換方式(interface 類型的轉換)
- Mongodb 利用mongoshell進行數據類型轉換的實現方法
- Go語言string,int,int64 ,float之間類型轉換方法
- GO語言類型轉換和類型斷言實例分析
- Go 第三方庫之類型轉換問題