>백엔드 개발 >Golang >fmt.Printf가 Go에서 예상했던 것과 다른 음의 정수에 대한 이진 표현을 표시하는 이유는 무엇입니까?

fmt.Printf가 Go에서 예상했던 것과 다른 음의 정수에 대한 이진 표현을 표시하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-02 16:11:02314검색

Why does fmt.Printf show a different binary representation for negative integers than expected in Go?

2의 보수와 fmt.Printf: 이진 표현 수수께끼 풀기

부호 있는 정수로 작업할 때 컴퓨터는 2의 보수를 사용하여 음수 값을 나타냅니다. . 이는 부호가 별도의 비트로 표시되는 일반적인 이진 표현과 다릅니다. 예를 들어 2의 보수에서 정수 -5는 1111 1011로 표시됩니다.

그러나 fmt.Printf를 사용하여 이진 표현을 인쇄하면 예기치 않은 결과가 발생할 수 있습니다. 예를 들어, 다음 코드 조각은

var i int8 = -5
fmt.Printf("%b", i)

놀랍게도 1111 1011 대신 -101을 출력합니다. 이러한 불일치로 인해 2의 보수가 실제로 내부 표현에 사용되고 있는지 또는 형식이 모호한지에 대한 의문이 제기되었습니다. 올바른 표현입니다.

이 문제를 밝히기 위해 fmt.Printf가 이진수 형식을 어떻게 지정하는지 자세히 알아볼 필요가 있습니다. 범인은 음수 부호 있는 정수를 양수로 자동 변환하는 fmt.integer 함수에 있습니다. 이 변환에는 정수를 부정하고 출력 문자열 앞에 - 기호를 추가하는 작업이 포함됩니다. 따라서 -101 출력은 5의 이진 표현에 -가 추가된 표현입니다.

이를 더 자세히 설명하려면 부호 있는 정수를 부호 없는 정수로 변환한 다음 fmt.Printf를 사용하여 형식을 지정하면 올바른 2가 생성됩니다. 보수 표현:

var u uint8 = uint(i)
fmt.Printf("%b", u)

이것은 정확히 -5의 2의 보수인 11111011을 출력합니다.

따라서 Go에서 부호 있는 정수의 내부 표현은 2의 보수 규칙을 따릅니다. 부호 있는 정수 형식을 지정할 때 잘못된 것처럼 보이는 이진 표현은 fmt.integer가 수행하는 자동 변환 및 부호 추가로 인해 발생합니다. Go에서 부호 있는 정수 및 이진 표현으로 작업할 때 이 동작을 이해하는 것이 필수적입니다.

위 내용은 fmt.Printf가 Go에서 예상했던 것과 다른 음의 정수에 대한 이진 표현을 표시하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.