Go TCP 讀取是非阻塞的:解決不完整的資料接收
在Go 中,TCP 讀取是非阻塞的,這意味著它們立即返回任何可用的數據,即使它低於預期。此行為與 C 的阻塞讀取不同,C 的阻塞讀取會等到收到所需的資料量為止。
非阻塞讀取的原因
TCP 作為位元組流運行,在傳輸過程中可能會出現碎片。因此,僅根據接收到的位元組數無法確定訊息的結束。這就需要自訂分隔符號或其他機制來確定訊息邊界。
資料不完整的解決方案
要讀取特定數量的字節,請使用 io.ReadAtLeast 或 io.ReadFull 。對於任意條件,循環讀取調用,直到沒有錯誤或滿足指定條件。
範例:
package main
import (
"fmt"
"net"
"time"
)
func main() {
conn, _ := net.Dial("tcp", "127.0.0.1:4243")
// Set a deadline to prevent hanging reads
_ = conn.SetReadDeadline(time.Now().Add(10 * time.Second))
// Loop to read until a newline is encountered
for {
buf := make([]byte, 512)
n, err := conn.Read(buf)
if err != nil {
fmt.Println(err)
break
}
if n > 0 {
str := string(buf[:n])
if str[len(str)-1] == '\n' {
fmt.Println(str)
break
}
}
}
}
其他注意事項
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3