Go에서 JSON을 구문 분석할 때 32비트보다 큰 정수는 기본 JSON 디코더에 의해 자동으로 float64 값으로 변환될 수 있습니다. 이는 이러한 정수의 정확성을 유지해야 할 때 문제가 됩니다.
이 문제에 대한 한 가지 해결책은 사용자 정의 디코더를 사용하고 UseNumber 메서드를 사용하는 것입니다. 이를 통해 숫자를 json.Number 유형으로 디코딩하여 쉽게 다시 정수로 변환할 수 있습니다.
package main import ( "bytes" "encoding/json" "fmt" "strconv" ) func main() { body := []byte("{\"tags\":[{\"id\":4418489049307132905},{\"id\":4418489049307132906}]}") dat := make(map[string]interface{}) d := json.NewDecoder(bytes.NewBuffer(body)) d.UseNumber() if err := d.Decode(&dat); err != nil { panic(err) } tags := dat["tags"].([]interface{}) n := tags[0].(map[string]interface{})["id"].(json.Number) i64, _ := strconv.ParseUint(string(n), 10, 64) fmt.Println(i64) // prints 4418489049307132905 }
또는 JSON 스키마와 일치하도록 사용자 정의 데이터 구조를 설계할 수 있습니다. 모든 크기의 정수.
package main import "encoding/json" import "fmt" type A struct { Tags []map[string]uint64 // "tags" } func main() { body := []byte("{\"tags\":[{\"id\":4418489049307132905},{\"id\":4418489049307132906}]}") var a A if err := json.Unmarshal(body, &a); err != nil { panic(err) } fmt.Println(a.Tags[0]["id"]) // logs 4418489049307132905 }
애플리케이션이 진정한 64비트 정수가 부족한 JavaScript와 통신하는 경우 마샬링 및 역마샬링 중에 데이터 손실이 발생할 수 있습니다.
위 내용은 Go에서 JSON 정수 정밀도를 유지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!