int64 的JSON 解析:在Go 中處理空值
在Go 中解析JSON 流時,處理空值可能是一個挑戰,尤其是處理int64 類型時。如提供的範例所示,嘗試將包含 null 值的 JSON 物件解組到 int64 類型的結構體欄位中將因類型不符而導致錯誤。
使用指向 Null 的指標值
此問題的一個簡單解決方案是使用指向 int64 的指標。指標可以是 nil,表示空值,也可以指向具有關聯值的有效 int64 實例。 Go 的 JSON 套件支援這種方法。
type World struct { Data *int64 }
透過修改上面的結構體定義以使用指向 int64 的指針,我們現在可以成功解組 JSON 數據,而不會遇到先前的錯誤。 *int64 允許 JSON 解析器將 null 值表示為 nil 指標。
將 null 對應到非 Null 值
如果需要,您可以將 null 值對應到非空值,例如 -1 或 MinValue。這可以透過解組後自訂處理 JSON 資料來實現。例如:
func MapNull(data *int64) int64 { if data == nil { return -1 } return *data }
透過在解組後呼叫 MapNull 函數,您可以將任何空值替換為所需的非空表示。
結論
Go 中解析包含 int64 類型的 JSON 資料時處理 null 值可以透過使用指向的指標來實現int64。該技術允許 JSON 解析器表示空值並保留原始資料結構。如有必要,可以應用自訂後處理將空值對應到替代的非空表示。
以上是在 Go 中解析 JSON int64 時如何處理空值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!