>  기사  >  백엔드 개발  >  C에서 이식 가능한 64비트 정수 바이트 순서 지정 기능을 구현하는 방법은 무엇입니까?

C에서 이식 가능한 64비트 정수 바이트 순서 지정 기능을 구현하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-01 01:33:28327검색

How to Implement a Portable 64-Bit Integer Byte Ordering Function in C  ?

C의 이식 가능한 64비트 정수 바이트 순서 지정 함수

질문:

htonl과 같은 표준 함수를 얻을 수 있습니까? C에서 64비트 정수와 작동하여 네트워크 바이트 순서로 변환할 수 있습니까?

답변:

C에는 htonll과 같이 명시적으로 정의된 함수가 없지만 표준 라이브러리를 사용하면 이식 가능한 구현을 만드는 것이 가능합니다. 다음은 두 가지 접근 방식입니다.

동적 엔디안 감지 사용:

<code class="cpp">#define htonll(x) ((1 == htonl(1)) ? (x) : ((uint64_t)htonl((x) & 0xFFFFFFFF) << 32) | htonl((x) >> 32))
#define ntohll(x) ((1 == ntohl(1)) ? (x) : ((uint64_t)ntohl((x) & 0xFFFFFFFF) << 32) | ntohl((x) >> 32))</code>
  • 매크로 htonll은 스와핑을 통해 64비트 정수 x를 네트워크 바이트 순서로 변환합니다. 대상 아키텍처가 리틀 엔디안인 경우 32비트 단어.
  • ntohll은 역방향 작업을 수행하여 네트워크 바이트 순서를 기본 바이트 순서로 변환합니다.

전처리기 매크로 사용 :

<code class="cpp">#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>
  • 이 접근 방식은 대부분의 컴파일러에서 제공하는 __BIG_ENDIAN__ 또는 __LITTLE_ENDIAN__ 전처리기 기호를 기반으로 하는 전처리기 매크로를 사용하여 htonll 및 ntohll을 정의합니다.
  • 아키텍처가 큰 경우- 엔디안(기호 정의)의 경우 바이트 스와핑이 필요하지 않으므로 함수는 단순히 입력 값을 반환합니다.
  • 리틀 엔디안 아키텍처의 경우 함수는 이전 예와 같이 바이트 스와핑을 수행합니다.

위 내용은 C에서 이식 가능한 64비트 정수 바이트 순서 지정 기능을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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