JSON Trailing Comma: A Runtime Conundrum in Go
Prinsip Dave Cheney untuk mengekori koma dalam literal komposit meluas ke penghuraian JSON. Walau bagaimanapun, apabila mengendalikan data JSON dengan koma di belakang, pengaturcara Go yang cerdik menghadapi ralat masa jalan. Artikel ini meneroka sebab asas di sebalik gelagat ini.
Tidak seperti literal komposit Go, yang memerlukan koma mengekor mengikut peraturan koma bertitik, sintaks JSON melarang sama sekali mengekor koma. Kod berikut menunjukkan isu ini:
<code class="go">type jsonobject struct { Objects []ObjectType `json:"objects"` } type ObjectType struct { Name string `json:"name"` } func main() { bytes := []byte(`{ "objects": [ {"name": "foo"}, // REMOVE THE COMMA TO MAKE THE CODE WORK! ]}`) jsontype := &jsonobject{} json.Unmarshal(bytes, &jsontype) fmt.Printf("Results: %v\n", jsontype.Objects[0].Name) // panic: runtime error: index out of range }</code>
Kod ini akan panik dengan "ralat masa jalan: indeks di luar julat" apabila cuba mengakses elemen pertama kepingan Objek. Sebab ralat ini ialah penghurai JSON menjangkakan JSON dibentuk dengan baik dan koma mengekor dalam contoh di atas menjadikannya tidak sah.
Menurut spesifikasi JSON, koma mengekor tidak dibenarkan dalam JSON tatasusunan atau peta. Oleh itu, walaupun sintaks Go membenarkannya, penghurai JSON akan mentafsirkannya sebagai ralat. Tingkah laku ini penting untuk mengekalkan kesalingoperasian dan mengelakkan ketidakkonsistenan antara penghurai JSON yang berbeza.
Kesimpulannya, apabila menghuraikan JSON dengan koma di belakang dalam Go, adalah penting untuk mematuhi spesifikasi JSON dan mengalih keluarnya. Percubaan untuk memaksa penghurai menerima koma di belakang adalah tidak digalakkan dan boleh membawa kepada ralat yang tidak dijangka atau isu keserasian.
Atas ialah kandungan terperinci Mengapa Tanda Tanda Koma dalam JSON Menyebabkan Ralat Masa Jalan dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!