我從閱讀文檔中了解到,string它本質上是不可變的[]byte,并且可以輕松地在兩者之間進行轉換。然而,當從 JSON 解組時,這似乎不是真的。以下面的示例程序為例:package mainimport ( "encoding/json" "fmt")type STHRaw struct { Hash []byte `json:"hash"`}type STHString struct { Hash string `json:"hash"`}func main() { bytes := []byte(`{"hash": "nuyHN9wx4lZL2L3Ir3dhZpmggTQEIHEZcC3DUNCtQsk="}`) stringHead := new(STHString) if err := json.Unmarshal(bytes, &stringHead); err != nil { return } rawHead := new(STHRaw) if err := json.Unmarshal(bytes, &rawHead); err != nil { return } fmt.Printf("String:\t\t%x\n", stringHead.Hash) fmt.Printf("Raw:\t\t%x\n", rawHead.Hash) fmt.Printf("Raw to string:\t%x\n", string(rawHead.Hash[:]))}這給出了以下輸出:String: 6e7579484e397778346c5a4c324c3349723364685a706d67675451454948455a63433344554e437451736b3dRaw: 9eec8737dc31e2564bd8bdc8af77616699a0813404207119702dc350d0ad42c9Raw to string: 9eec8737dc31e2564bd8bdc8af77616699a0813404207119702dc350d0ad42c9 相反,我希望每次都能收到相同的價值。有什么不同?
1 回答

犯罪嫌疑人X
TA貢獻2080條經驗 獲得超4個贊
encoding/json包的設計者決定應用程序必須在string
值中提供有效的 UTF-8 文本,并且應用程序可以在值中放置任意字節序列[]byte
。包 base64 對[]byte
值進行編碼以確保生成的字符串是有效的 UTF-8。
Marshal 函數文檔中[]byte
描述了值的編碼。
這個決定不是由 Go 語言的設計決定的。該string
類型可以包含任意字節序列。該[]byte
類型可以包含有效的 UTF-8 文本。
設計者可以在字段標簽中使用一個標志來指示應該對 astring
或[]byte
值進行編碼以及使用哪個編碼器,但這不是他們所做的。
- 1 回答
- 0 關注
- 208 瀏覽
添加回答
舉報
0/150
提交
取消