Gelagat Tidak Dijangka json.NewDecoder().Decode() Dalam Tarikh Akhir Konteks
Program In Go dengan tarikh akhir konteks ditetapkan, respons badan yang dibaca oleh ioutil.ReadAll() dijangka akan mengembalikan ralat (context.DeadlineExceeded). Walau bagaimanapun, tingkah laku ini tidak dipatuhi apabila membaca badan tindak balas dengan json.NewDecoder(resp.Body).Decode(), yang mengembalikan sifar.
Mari kita mendalami isu ini:
Mengikut maklum balas, pakej net/http mungkin menggunakan penimbal untuk memproses permintaan. Ini memerlukan badan tindak balas yang masuk boleh dibaca sebahagian atau keseluruhannya dan ditimbal sebelum masa anda melakukannya. Oleh itu, konteks yang tamat tempoh mungkin tidak menghalang anda daripada melengkapkan bacaan kandungan.
Untuk menggambarkan perkara ini dengan lebih jelas, kami melaraskan contoh untuk melancarkan pelayan HTTP ujian yang sengaja melambatkan respons sebahagiannya:
<code class="go">ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { s := []byte(`{"ip":"12.34.56.78"}`) w.Write(s[:10]) if f, ok := w.(http.Flusher); ok { f.Flush() } time.Sleep(time.Second * 6) w.Write(s[10:]) })) defer ts.Close() url = ts.URL readDoesntFail() readFails()</code>
Pelayan ujian ini mengeluarkan objek JSON yang menyerupai respons ip.jsontest.com. Berbeza dengan itu, ia hanya menyampaikan 10 bait badan pada mulanya, kemudian mengepamnya dan tidur selama 6 saat dengan sengaja sebelum menghantar bakinya, memberikan masa pelanggan untuk tamat tempoh.
Apabila kami melaksanakan readDoesntFail() dengan pelayan ini , kami dapat:
before reading response body, context error is: context deadline exceeded panic: Get "http://127.0.0.1:38230": context deadline exceeded goroutine 1 [running]: main.readDoesntFail() /tmp/sandbox721114198/prog.go:46 +0x2b4 main.main() /tmp/sandbox721114198/prog.go:28 +0x93
Sekarang, dengan contoh kami yang dikemas kini, json.Decoder.Decode() berusaha untuk membaca daripada sambungan kerana maklumat belum ditimbal, membenarkan tamat tempoh konteks menggesa ralat kerana konteks tamat tempoh.
Atas ialah kandungan terperinci Mengapakah `json.NewDecoder().Decode()` tidak mengembalikan ralat tarikh akhir konteks apabila `ioutil.ReadAll()` melakukannya dalam tarikh akhir konteks dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!