해시 함수 출력을 위해 uint64를 int64로 변환
murmur2와 같이 uint64 값을 반환하는 해시 함수로 작업하고 결과를 저장할 때 BIGINT(int64)만 지원하는 PostgreSQL과 같은 데이터베이스에서는 uint64를 int64로 변환합니다.
해결책: 유형 변환
가장 간단한 해결책은 유형 변환을 사용하는 것입니다.
i := uint64(0xffffffffffffffff) i2 := int64(i)
이 변환은 다음과 같이 성공합니다. 메모리 표현은 변경되지 않고 유형만 변경됩니다. 결과 int64 값은 원래 uint64와 동일한 이진 표현을 갖습니다.
출력:
18446744073709551615 -1
추가 참고:
유형이 지정되지 않은 정수 상수 값을 int64로 직접 변환하면 컴파일이 발생할 수 있습니다. 시간 오류. 상수 값이 int64의 범위에 맞지 않을 수 있기 때문입니다. 예:
i3 := int64(0xffffffffffffffff) // Compile time error!
이는 상수 값 0xffffffffffffffff가 임의의 정밀도를 가지며 int64의 최대값인 0x7ffffffffffffffff를 초과하기 때문입니다.
위 내용은 uint64 해시 출력을 데이터베이스 저장소용 int64로 안전하게 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!