大文字小文字変換のための XOR トリックの探索 (^= 32)
コーディングの領域では、次のような独特のテクニックが時折登場します。大文字と小文字を変換するための謎の「^= 32」演算。この手法は、多くのプログラマを頭を悩ませ、一見魔法のように見える効果がどのように実現されるのか疑問に思っています。
この型破りなアプローチの内部の仕組みを詳しく見てみましょう:
バイナリの観点
ASCII コード テーブルは、文字とその数値表現の間のマッピングを提供します。バイナリで。興味深いことに、特定の文字の小文字と大文字のバイナリの差は定数値 32 です。
バイナリ XOR Demystified
XOR (排他的論理和) はバイナリです。 2つのビットを比較する演算。両方のビットが 0 または両方のビットが 1 の場合、結果は 0 になります。それ以外の場合、結果は 1 になります。
^= 演算子
「^=」演算子は、変数と変数の間で XOR 演算を実行するビット単位の論理演算子です。指定された値を返し、結果を変数に代入します。
ケースの実装変換
文字に適用すると、「^= 32」は小文字と大文字を区別するバイナリ表現のビットを効果的に反転し、実質的に文字の大文字と小文字を切り替えます。
例
で提供されている例を考えてみましょう。質問:
char foo = 'a'; foo ^= 32; char bar = 'A'; bar ^= 32;
最初、「a」はバイナリで「1100001」と表現され、「A」は「1000001」になります。 "^= 32" を実行した後の結果は次のようになります。
コード スニペットから明らかなように、「foo」は「A」になり、 'bar' が 'a' になり、大文字小文字の変換が成功したことがわかります。
結論
^= 32 手法は、文字のバイナリ表現と次の能力を活用します。 XOR はケースを効率的に切り替え、ケース変換タスクに簡潔で洗練されたソリューションを提供します。
以上がXOR トリック (^= 32) はプログラミングにおける大文字と小文字の変換にどのように機能しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。