はじめに:
多くのネットワーク プロトコルでは、64 ビット整数を格納する必要があります。 -「ネットワークバイトオーダー」のビット整数。これはホストのバイト順序と異なるため、互換性の問題が発生する可能性があります。幸いなことに、32 ビット整数の場合、htonl 関数はネットワーク バイト オーダーへの変換に広く使用されています。開発者は多くの場合、64 ビット整数に類似した関数を探します。この記事では、そのような関数が利用できるかどうかを調査し、利用できない場合の実装を示します。
標準関数の存在:
残念ながら、標準の htonll 関数はありません。 C 標準ライブラリまたは広く採用されているポータブル ライブラリ。
実装:
標準関数がない場合は、独自のポータブル バージョンを実装できます。ここでは 2 つのアプローチを示します。
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 中国語 Web サイトの他の関連記事を参照してください。