> 백엔드 개발 > Golang > Go `big.Int`가 0인지 어떻게 효율적으로 테스트할 수 있나요?

Go `big.Int`가 0인지 어떻게 효율적으로 테스트할 수 있나요?

DDD
풀어 주다: 2024-11-25 03:24:14
원래의
403명이 탐색했습니다.

How Can I Efficiently Test if a Go `big.Int` is Zero?

big.Int가 0인지 테스트하는 효율적인 방법

Go에서 큰 정수로 작업할 때 값을 테스트하는 것이 중요합니다. 0 효율적입니다. 전통적인 접근 방식에서는 big.Int를 0을 나타내는 다른 big.Int와 비교하는 작업이 포함됩니다(예: Cmp(zero) == 0 사용). 그러나 big.Ints의 기본 표현을 활용하는 더 빠른 대안이 있습니다.

원시 바이트 사용(바이트 액세스)

big.Int는 Int.Bits( ) 함수는 정수 표현의 원시 바이트에 대한 액세스를 제공합니다. 이는 기본 데이터 복사를 방지하므로 빠른 방법입니다. 이 바이트 슬라이스의 길이를 확인하여 big.Int가 0인지 확인할 수 있습니다.

if len(i1.Bits()) == 0 {
    // i1 is 0
}
로그인 후 복사

비트 길이 사용

또는 다음을 사용할 수 있습니다. big.Int의 유효 비트 수를 반환하는 Int.BitLen() 함수. 0의 비트 길이는 0이므로 다음과 같이 0인지 테스트할 수 있습니다.

if i1.BitLen() == 0 {
    // i1 is 0
}
로그인 후 복사

벤치마크 결과

이러한 기술을 기존 비교 방법과 비교하여 벤치마킹하면 상당한 결과가 나타납니다. 성능 개선:

  • 원시 바이트 가져오기 및 길이 확인은 약 20배입니다. 더 빠릅니다.
  • Int.BitLen()을 사용하는 것이 약 10배 더 빠릅니다.

하위 수준 속성을 사용하여 1 테스트

A big.Int가 1과 같은 경우 유사한 최적화를 테스트에 적용할 수 있습니다. 그러나 0은 고유한 속성을 가지므로 이 최적화는 다음과 같습니다. 그다지 중요하지 않음:

func isOne(i *big.Int) bool {
    bits := i.Bits()
    return len(bits) == 1 && bits[0] == 1 && i.Sign() > 0
}
로그인 후 복사

기존 비교에 대해 이 기술을 벤치마킹하면 약 10배의 성능 향상이 나타납니다.

결론

위에 설명된 방법 big.Int가 0인지 1인지 테스트하는 효율적인 방법을 제공하여 표현의 하위 수준 속성을 활용하고 기존에 비해 성능을 향상시킵니다. 비교 접근 방식. 이러한 기술은 특히 시간이 중요한 애플리케이션에서 큰 정수를 조작하는 코드 속도를 향상시킬 수 있습니다.

위 내용은 Go `big.Int`가 0인지 어떻게 효율적으로 테스트할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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