Go에서 Int64를 Int로 변환: 오류 방지
Go에서 두 유형을 비교할 때 int64를 int로 변환하는 것이 어려울 수 있습니다. 이 문서에서는 예기치 않은 결과를 방지하기 위해 이 변환에 권장되는 접근 방식을 살펴봅니다.
큰 유형으로 변환
정확성을 보장하려면 더 작은 유형( 이 경우 int)를 더 큰 유형(int64)으로 변경합니다. 이는 유형 변환을 사용하여 달성할 수 있습니다.
var a int var b int64 int64(a) < b
잘림 문제
값을 비교할 때 더 큰 유형을 더 작은 유형으로 변환하면 데이터가 손실되거나 잘릴 수 있습니다. 다음 예를 고려하십시오.
var x int32 = 0 var y int64 = math.MaxInt32 + 1 // y == 2147483648 if x < int32(y) { // This evaluates to false because int32(y) is -2147483648 }
이 시나리오에서 int64(y)를 int32로 변환하면 -2147483648이 되어 원래 값의 상위 비트가 손실됩니다.
최적화된 변환 maxInt
maxInt int64 값의 경우 다음 변환 사용을 고려하세요.
for a := 2; a < int(maxInt); a++ { // Execute correctly even if maxInt exceeds the maximum value of int }
maxInt를 int로 변환하고 int()를 사용하여 올바른 int 하위 유형이 다음과 같은지 확인합니다. 사용하면 원하는 비교를 보장하면서 오버플로 문제를 피할 수 있습니다.
결론
유형 크기를 신중하게 고려하여 int64에서 int 변환으로 접근하면 오류를 방지하고 정확한 비교를 보장하는 데 도움이 됩니다. . 작은 유형을 더 큰 유형으로 변환하는 원칙을 고수함으로써 개발자는 Go에서 다양한 숫자 유형으로 작업할 때 데이터 손실을 방지하고 신뢰할 수 있는 결과를 얻을 수 있습니다.
위 내용은 Go에서 int64를 int로 안전하게 변환하는 방법: 데이터 손실 및 오버플로 방지?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!