Go에서 네트워크 애플리케이션을 사용할 때 net.Conn.Read 메서드를 사용하면 편리한 방법을 제공합니다. 연결에서 데이터를 수신합니다. 그러나 미리 결정된 바이트 배열을 읽어서 작동하므로 개발자는 정확한 데이터 길이를 예측해야 합니다.
고정 길이 지정 make([]byte, 2048)와 같은 길이 바이트 배열은 두 가지 잠재적인 문제를 일으킬 수 있습니다.
이러한 한계를 극복하기 위해 두 개의 io 호환 연결 간에 데이터를 전송하는 강력하고 효율적인 접근 방식을 제공하는 io.Copy 기능을 활용할 수 있습니다. bytes.Buffer 객체를 생성하고 net.Conn의 데이터를 여기에 파이프함으로써 필요에 따라 버퍼를 동적으로 확장하여 정확한 양의 데이터가 캡처되도록 할 수 있습니다.
다음은 정확한 데이터 읽기를 위해 io.Copy를 사용하는 방법을 보여주는 예제 코드 조각입니다.
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() fmt.Fprintf(conn, "GET / HTTP/1.0\r\n\r\n") var buf bytes.Buffer io.Copy(&buf, conn) fmt.Println("total size:", buf.Len()) }
이 예제에서는 Google 웹 서버에 대한 TCP 연결을 시작하고 HTTP 요청을 전송하며 동적으로 bytes.Buffer 및 io.Copy를 사용하여 응답 데이터를 캡처합니다. 결과 buf 객체에는 완전한 응답이 포함되어 전송된 데이터의 정확한 양을 읽을 수 있습니다.
이 접근 방식을 활용하면 사전 정의된 바이트 배열에 따른 제한 없이 네트워크 연결에서 데이터를 안정적으로 수신할 수 있습니다.
위 내용은 Golang을 사용하여 net.Conn에서 정확한 양의 데이터를 어떻게 읽을 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!