>  기사  >  백엔드 개발  >  Go에서 정수 오버플로를 감지하는 방법은 무엇입니까?

Go에서 정수 오버플로를 감지하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-06 18:35:03512검색

How to Detect Integer Overflow in Go?

Go에서 정수 오버플로 감지

정수 오버플로는 산술 연산의 결과가 해당 데이터 유형이 표현할 수 있는 최대값 또는 최소값을 초과할 때 발생합니다. . Go에서 정수는 부호 있는 정수 또는 부호 없는 정수를 사용하여 표현되며, 32비트와 64비트가 가장 일반적입니다.

정수 오버플로를 감지하기 위한 "올바른" 방법은 결과를 최대값과 비교하는 것입니다. 데이터 유형의 최소값입니다. 예를 들어 32비트 덧셈의 경우 두 개의 양의 정수의 합이 최대값(2^31 - 1)을 초과하거나 두 개의 음의 정수의 합이 최소값(-2^31)보다 작은 경우 오버플로가 발생합니다.

다음 코드를 고려하세요.

a, b := 2147483647, 2147483647 // 32-bit integers
c := a + b

c가 오버플로되었는지 확인하려면 이를 최대 32비트 정수와 비교할 수 있습니다.

if c > math.MaxInt32 {
    // Integer overflow occurred
}

마찬가지로, 64비트 덧셈, 두 개의 양의 정수의 합이 최대값(2^63 - 1)을 초과하거나 두 개의 음의 정수의 합이 최소값(-2^63)보다 작은 경우 오버플로가 발생합니다. 검사 방법은 다음과 같습니다.

if c > math.MaxInt64 {
    // Integer overflow occurred
}

대체 접근 방식은 사용자 정의 오류 처리를 사용하는 것입니다. 오류 변수를 정의하고 오버플로가 없으면 nil로 설정할 수 있습니다.

var errOverflow error

if right > 0 {
    if left > math.MaxInt32-right {
        errOverflow = errors.New("integer overflow")
    }
} else {
    if left < math.MinInt32-right {
        errOverflow = errors.New("integer overflow")
    }
}

그런 다음 작업 후 오류 변수를 확인할 수 있습니다.

if errOverflow != nil {
    // Integer overflow occurred
}

위 내용은 Go에서 정수 오버플로를 감지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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