btowc
From cppreference.com
| ヘッダー <wchar.h> で定義 |
||
| wint_t btowc( int c ); |
(C95 以降) | |
単バイト文字c(unsigned charとして再解釈される)を、そのワイド文字相当に変換します。
ほとんどのマルチバイト文字エンコーディングは、ASCII文字セットの文字を表すために単バイトコードを使用します。この関数は、そのような文字をwchar_tに変換するために使用できます。
目次 |
[編集] パラメータ
| c | - | 変換する単バイト文字 |
[編集] 戻り値
cがEOFの場合、WEOF
cのワイド文字表現。ただし、(unsigned char)cが初期シフト状態において有効な単バイト文字である場合。WEOFそれ以外の場合。
[編集] 例
このコードを実行
#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