> 백엔드 개발 > Golang > Go에서 `fmt.Println`이 `*bytes.Buffer`와 `bytes.Buffer`에 대해 서로 다른 출력을 표시하는 이유는 무엇입니까?

Go에서 `fmt.Println`이 `*bytes.Buffer`와 `bytes.Buffer`에 대해 서로 다른 출력을 표시하는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-11-22 14:20:34
원래의
405명이 탐색했습니다.

Why Does `fmt.Println` Show Different Outputs for `*bytes.Buffer` and `bytes.Buffer` in Go?

다른 인쇄 출력의 흥미로운 사례: *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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿