>백엔드 개발 >Golang >비트 연산에서 유형이 지정되지 않은 상수를 사용할 때 Go에서 오버플로 오류가 발생하는 이유는 무엇입니까?

비트 연산에서 유형이 지정되지 않은 상수를 사용할 때 Go에서 오버플로 오류가 발생하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-30 13:38:02829검색

Why Does Go Throw an Overflow Error When Using Untyped Constants in Bitwise Operations?

Go 상수의 정수 오버플로 이해

Go 프로그래밍에서 지나치게 큰 값을 정수 상수에 맞추려고 하면 컴파일이 발생할 수 있습니다. 오류. 다음 코드 조각을 고려하세요.

<code class="go">userid := 12345
did := (userid & ^(0xFFFF << 48))</code>

이 코드를 컴파일할 때 다음 오류가 발생할 수 있습니다.

./xxxx.go:511: constant -18446462598732840961 overflows int

이 오류는 Go에서 유형이 지정되지 않은 상수 표현식의 특성으로 인해 발생합니다.

유형이 지정되지 않은 상수 및 정수 오버플로

주어진 코드에서 상수 ^(0xFFFF << 48)는 유형이 지정되지 않은 값을 갖습니다. 즉, 임의로 큰 값을 보유할 수 있음을 의미합니다. 정수. 그러나 형식화된 정수 userid를 사용하여 비트 AND 연산을 수행하려고 하면 컴파일러는 형식화되지 않은 상수를 int 형식으로 캐스팅하려고 시도합니다. 결과 값 -18446462598732840961이 int의 표현 가능한 최대 값을 초과하여 오버플로 오류가 발생합니다.

오버플로 문제 해결

이 오버플로 오류를 방지하려면, 형식화되지 않은 상수를 명시적으로 입력하는 것이 중요합니다. 이 경우 다음 코드를 대신 사용할 수 있습니다.

<code class="go">userid := 12345
did := (userid & (uint64(1<<48) - 1))</code>

uint64(1<<48) - 1을 사용하여 상수를 uint64로 명시적으로 캐스팅하면 비트 AND 연산에서 두 피연산자가 모두 사용되도록 할 수 있습니다. 동일한 유형을 사용하여 오버플로 문제를 제거합니다.

위 내용은 비트 연산에서 유형이 지정되지 않은 상수를 사용할 때 Go에서 오버플로 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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