Go에서는 들어오는 데이터 패킷을 읽는 net.Conn.Read를 사용하여 원시 네트워크 연결에 액세스할 수 있습니다. 바이트 배열로. 그러나 들어오는 데이터의 정확한 크기를 모르는 경우 고정 크기 배열을 읽으면 데이터가 잘리거나 불필요한 버퍼링이 발생할 수 있습니다.
이를 처리하려면 다음을 사용하여 보다 유연한 접근 방식을 사용할 수 있습니다. bufio 패키지 또는 대체 기술.
bufio 패키지는 Reader 유형을 제공합니다. 덩어리. net.Conn 연결에서 Reader 객체를 생성한 다음 ReadSlice 또는 ReadBytes 메서드를 사용하여 특정 구분 기호를 만나거나 입력 끝에 도달할 때까지 데이터를 읽을 수 있습니다. 예를 들어, 패킷 끝까지 데이터를 읽으려면 다음 코드를 사용할 수 있습니다.
package main import ( "bufio" "fmt" "net" ) func main() { conn, err := net.Dial("tcp", "google.com:80") if err != nil { fmt.Println("dial error:", err) return } defer conn.Close() // Create a bufio.Reader from the net.Conn reader := bufio.NewReader(conn) // Read data in chunks until the end of the packet buf := []byte{} for { chunk, err := reader.ReadSlice('\n') if err != nil { if err != io.EOF { fmt.Println("read error:", err) } break } buf = append(buf, chunk...) } fmt.Println("total size:", len(buf)) // fmt.Println(string(buf)) }
또는 bytes.Buffer 유형을 사용하여 수신을 추가할 수 있습니다. 데이터 청크를 분할하고 전체 크기를 누적합니다.
package main import ( "bytes" "fmt" "io" "net" ) func main() { conn, err := net.Dial("tcp", "google.com:80") if err != nil { fmt.Println("dial error:", err) return } defer conn.Close() // Create a bytes.Buffer to accumulate incoming data var buf bytes.Buffer // Copy data from the net.Conn to the Buffer if _, err = io.Copy(&buf, conn); err != nil { fmt.Println("copy error:", err) } fmt.Println("total size:", buf.Len()) }
이러한 접근 방식 중 하나를 사용하면 데이터 없이 다양한 데이터 길이를 처리할 수 있습니다. 잘림 또는 과도한 버퍼링을 방지하여 Go에서 네트워크 연결을 통한 효율적인 데이터 전송을 보장합니다.
위 내용은 Go의 `net.Conn`에서 데이터를 청크로 읽는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!