소개:
많은 네트워크 프로토콜에서는 64비트를 저장해야 합니다. -bit "네트워크 바이트 순서"의 정수입니다. 이는 호스트 바이트 순서와 다르므로 잠재적으로 호환성 문제가 발생할 수 있습니다. 다행히 32비트 정수의 경우 htonl 함수는 네트워크 바이트 순서로 변환하는 데 널리 사용됩니다. 개발자는 종종 64비트 정수에 대해 유사한 함수를 찾습니다. 이 문서에서는 이러한 기능의 가용성을 살펴보고 사용할 수 없는 경우 구현을 제공합니다.
표준 함수의 존재:
안타깝게도 표준 htonll 함수는 없습니다. C 표준 라이브러리 또는 널리 채택된 휴대용 라이브러리.
구현:
표준 기능이 없는 경우 자체 휴대용 버전을 구현할 수 있습니다. 다음은 두 가지 접근 방식입니다.
1. 런타임 바이트 스와핑:
이 접근 방식은 htonl(1)을 사용하여 런타임 시 엔디안을 확인하여 바이트 스와핑이 필요한지 여부를 결정합니다. 바이트 교환이 필요한 경우 htonl을 사용하여 64비트 정수의 32비트 절반을 교환합니다. 이 접근 방식의 코드는 다음과 같습니다.
<code class="c++">#define htonll(x) ((1==htonl(1)) ? (x) : ((uint64_t)htonl((x) & 0xFFFFFFFF) << 32) | htonl((x) >> 32))</code>
2. 컴파일 시간 바이트 스와핑:
__BIG_ENDIAN__과 같은 전처리기 매크로를 정의하는 컴파일러에 액세스할 수 있는 경우 이를 사용하여 컴파일 시간에 바이트 스와핑 프로세스를 최적화할 수 있습니다. 예는 다음과 같습니다.
<code class="c++">#if __BIG_ENDIAN__ # define htonll(x) (x) # define ntohll(x) (x) #else # define htonll(x) (((uint64_t)htonl((x) & 0xFFFFFFFF) << 32) | htonl((x) >> 32)) # define ntohll(x) (((uint64_t)ntohl((x) & 0xFFFFFFFF) << 32) | ntohl((x) >> 32)) #endif</code>
결론:
결론적으로 C에는 표준 htonll 함수가 없습니다. 그러나 런타임이나 컴파일 타임에 엔디안을 결정하는 이식 가능한 구현을 제공하여 64비트 정수를 네트워크 바이트 순서로 변환할 수 있습니다.
위 내용은 C에서 64비트 정수를 네트워크 바이트 순서로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!