C 11 の文字列リテラルの Unicode エンコーディング
C 11 では、Unicode エンコーディングを容易にするために新しい文字型と文字列リテラルが導入されました。この記事では、これらの新機能の使用法とセマンティクスを検討し、次の質問に対処します。
文字参照と文字列型
は "x/ u/U" 文字参照はすべての文字列と結合可能タイプ?
答え: いいえ。「x」はすべての文字列で使用できますが、「u」と「U」は UTF エンコードされた文字列に制限されます。
固定幅文字列
文字列型は固定幅ですか、それとも「x/u/U」参照はバイト数を拡張しますか?
答え: 文字列内のコード単位の数はエンコーディングによって異なりますが、配列内の要素の数は変わりません。
"u"" および "u8"" 文字列の UTF エンコーディング セマンティクス
Do "u" 「」および「u8」」文字列にはエンコード セマンティクスがあり、非 BMP コードのエンコードが可能です。ポイント?
答え: はい、「u"」は UTF-16 エンコード文字列を作成し、「u8"」は UTF-8 エンコード文字列を作成します。非 BMP コード ポイントは、それに応じてエンコードされます。
「u」を使用したローン サロゲートの使用
単独で使用できますサロゲートは次を使用して記述できます"u"?
答え: いいえ、仕様では、UTF-16 サロゲート ペア (0xD800-0xDFFF) を "u" または "U" のコード ポイントとして使用することを禁止しています。
文字列での認識のエンコード関数
文字列関数はエンコードを認識しますか?
答え: いいえ、標準の文字列関数はエンコードを認識せず、Unicode 文字列を考慮します。コードポイントではなく、コード単位のシーケンスとして。無効なバイト シーケンスは検出できません。
結論
C 11 文字列リテラルにおける Unicode エンコードのこの調査では、新しい文字の包括的な概要が提供されます。型、文字列リテラル、およびそれらのエンコード セマンティクス。これにより、その使用法と制限が明確になり、開発者が C 11 での Unicode サポートを効果的に利用できるようになります。
以上がC 11 文字列リテラルは Unicode エンコーディングをどのように処理しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。