다른 인쇄 출력의 흥미로운 사례: *bytes.Buffer 대 bytes.Buffer
Go에서 바이트로 작업할 때 포인터 값과 포인터가 아닌 값의 미묘한 차이로 인해 예상치 못한 인쇄 결과가 발생할 수 있습니다.
다음을 실행하면 코드:
buf := new(bytes.Buffer) buf.WriteString("Hello World") fmt.Println(buf)
익숙한 출력인 "Hello World"가 표시됩니다. 이는 *bytes.Buffer와 같은 포인터 값의 경우 Go가 해당 값에 String() 메서드가 있는지 확인하기 때문입니다. 이 경우 *bytes.Buffer는 String()을 구현하고 해당 호출로 인해 버퍼의 내용이 문자열로 인쇄됩니다.
그러나 bytes.Buffer와 같이 포인터가 아닌 값에 대해 실행되는 동일한 코드는 다르게 동작합니다. :
var buf bytes.Buffer buf.WriteString("Hello World") fmt.Println(buf)
예상된 문자열 표현 대신 다음과 같은 출력이 표시됩니다.
{[72 101 108 108 111 32 119 111 114 108 100] 0 [72 101 108 108 111 32 119 111 114 108 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]} 0
이것은 겉으로는 암호화된 출력은 필드 및 패딩 바이트를 포함하여 bytes.Buffer 구조체의 메모리 레이아웃을 나타냅니다.
이러한 차이의 이유는 Go가 값 인쇄를 처리하는 방식에 있습니다. 인쇄되는 값에 String() 메서드가 있는지 확인하고, 그렇다면 이를 사용하여 문자열 표현을 얻습니다. 포인터 유형 *bytes.Buffer의 경우 String() 메서드가 있으므로 해당 내용이 문자열로 인쇄됩니다. 그러나 포인터가 아닌 유형 bytes.Buffer의 경우 String() 메소드가 구현되지 않아 개별 필드의 기본 형식이 지정됩니다.
작업할 때 놀라움을 피하기 위해 이러한 차이점을 염두에 두는 것이 중요합니다. Go에서는 바이트와 버퍼를 사용합니다. 포인터 값과 포인터가 아닌 값의 다양한 동작을 이해하면 더욱 예측 가능하고 강력한 코드를 작성하는 데 도움이 됩니다.
위 내용은 Go에서 `fmt.Println`이 `*bytes.Buffer`와 `bytes.Buffer`에 대해 서로 다른 출력을 표시하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!