btowc
提供: cppreference.com
ヘッダ <wchar.h> で定義
|
||
wint_t btowc( int c ); |
(C95以上) | |
シングルバイト文字 c
(unsigned char として再解釈されます) を同等なワイド文字にワイド化します。
ほとんどのマルチバイト文字エンコーディングは ASCII 文字集合の文字を表すためにシングルバイトのコードを使用します。 この関数はそのような文字を wchar_t に変換するために使用することができます。
目次 |
[編集] 引数
c | - | ワイド化するシングルバイト文字 |
[編集] 戻り値
c
が EOF の場合は WEOF。
(unsigned char)c が初期シフト状態において有効なシングルバイト文字であれば c
のワイド文字表現、そうでなければ WEOF。
[編集] 例
Run this code
#include <stdio.h> #include <wchar.h> #include <locale.h> #include <assert.h> void try_widen(unsigned char c) { wint_t w = btowc(c); if(w != WEOF) printf("The single-byte character %#x widens to %#x\n", c, w); else printf("The single-byte character %#x failed to widen\n", c); } int main(void) { char *loc = setlocale(LC_ALL, "lt_LT.iso88594"); assert(loc); printf("In Lithuanian ISO-8859-4 locale:\n"); try_widen('A'); try_widen('\xdf'); // German letter ß (U+00df) in ISO-8859-4 try_widen('\xf9'); // Lithuanian letter ų (U+0173) in ISO-8859-4 setlocale(LC_ALL, "lt_LT.utf8"); printf("In Lithuanian UTF-8 locale:\n"); try_widen('A'); try_widen('\xdf'); try_widen('\xf9'); }
出力例:
In Lithuanian ISO-8859-4 locale: The single-byte character 0x41 widens to 0x41 The single-byte character 0xdf widens to 0xdf The single-byte character 0xf9 widens to 0x173 In Lithuanian UTF-8 locale: The single-byte character 0x41 widens to 0x41 The single-byte character 0xdf failed to widen The single-byte character 0xf9 failed to widen