bytes 인쇄 시 다른 동작.Buffer in Go
Go에서는 bytes 유형의 값을 인쇄하는 동작이 다릅니다.Buffer는 다음에 따라 다릅니다. 포인터인지 포인터가 아닌 값인지.
다음 코드를 고려하세요. 예:
buf := new(bytes.Buffer) buf.WriteString("Hello world") fmt.Println(buf)
이 경우 * 연산자를 사용하여 버퍼 포인터를 역참조하면 bytes.Buffer 유형의 String() 메서드가 호출됩니다. 이 메소드는 버퍼 내용의 문자열 표현을 반환하여 "Hello World"가 인쇄되도록 합니다.
이제 다음과 같이 코드를 수정해 보겠습니다.
var buf bytes.Buffer buf.WriteString("Hello world") fmt.Println(buf)
* 연산자를 사용하지 않고, 우리는 bytes.Buffer 유형의 포인터가 아닌 값을 전달하고 있습니다. 이전 예제와 달리 이 경우 fmt 패키지는 String() 메서드를 호출하지 않습니다. 대신 기본 형식을 사용하여 버퍼를 구조체 값으로 인쇄합니다.
{[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의 내부 구조를 나타냅니다.
이 두 예제의 주요 차이점은 String() 메서드에 있습니다. *bytes.Buffer 유형의 값을 인쇄할 때 fmt 패키지는 String() 메서드를 사용하여 버퍼 내용의 문자열 표현을 얻습니다. bytes.Buffer 유형의 포인터가 아닌 값에는 이 메서드가 없으므로 기본 구조체 형식이 사용됩니다.
위 내용은 Go에서 `bytes.Buffer`를 인쇄하면 포인터인지 아닌지에 따라 다른 출력이 생성되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!