多バイト文字及びワイド文字拡張ユーティリティ (Wide Character)
| ヘッダ ファイル |
wchar.h |
|---|---|
| 規格 | C95 |
| 概要 | ワイド文字の入出力に有用な幾つかの関数を宣言する。ワイド文字の入出力関数は、プログラムの内部的な基本単位がワイド文字であることを除いて、stdio.h で規定しているほとんどの関数と類似する機能を提供する。 |
プラグマ
型
| 名前 | 機能 |
|---|---|
| mbstate_t | マルチバイト文字とワイド文字間の変換状態を表す型です。 |
| wint_t | wchar_t 型の値と WEOF を格納できる型です。 |
| (size_t) | sizeof() が返す符号なし整数型です。 |
| (tm) | 時間を要素に分解して定義する構造体です。 |
| (wchar_t) | ワイド文字を表現できる型です。 |
マクロ
| 名前 | 機能 |
|---|---|
| WEOF | ワイド文字単位のファイルの終わり(EOF)に到達したことを示す wint_t 型の定数です。 |
| (NULL) | 任意のデータオブジェクトポインタと互換性があるヌルポインタ定数です。 |
| (WCHAR_MIN) | wchar_t の下限値。 |
| (WCHAR_MAX) | wchar_t の上限値。 |
引数付きマクロ
関数
入出力 (stdio.h)
| 名前 | 機能 |
|---|---|
| fwide() 1 | ストリームの入出力単位を決定します。 modeが0より大きい場合、ワイド文字単位とみなします。 |
同等の 1 バイト文字用関数が stdio.h にあります。
| 名前 | 機能 |
|---|---|
| fgetwc() | ストリームから文字を取得します。 |
| fgetws() | ストリームから文字列を取得します。 |
| fputwc() | ストリームに 1 文字を出力します。 |
| fputws() | ストリームに文字列を出力します。 |
| fwprintf() | ストリームに書式付き出力を書き込みます。 |
| fwscanf() | ストリームからの入力をスキャンして書式設定します。 |
| getwc() | ストリームから文字を取得します。 |
| getwchar() | stdin から文字を取得します。getwc(stdin)。 |
| putwc() | 文字をストリームに出力します。 |
| putwchar() | 文字を stdout に出力します。putwc(c, stdout)。 |
| swprintf() | 文字列に書式付き出力を書き込みます。 |
| swscanf() | 文字列からの入力をスキャンして書式設定します。 |
| ungetwc() | 入力ストリームに 1 文字を戻します。 |
| vfwprintf() | ストリームに書式付き出力を書き込みます。 |
| vfwprintf() | ストリームに書式付き出力を書き込みます。 |
| vfwscanf() 1 | ストリームからの入力をスキャンして書式設定します。 |
| vswprintf() | 文字列に書式付き出力を書き込みます。 |
| vswscanf() 1 | ストリームからの入力をスキャンして書式設定します。 |
| vwprintf() | stdout に書式付き出力を書き込みます。 |
| vwscanf() 1 | stdin からの入力をスキャンして書式設定します。 |
| wprintf() | 書式付き出力を stdout に書き込みます。 |
| wscanf() | stdin ストリームからの入力を、スキャンおよび書式設定します。 |
wprintf() と wscanf()
wprintf() 系と wscanf() 系の分類です。
| 接頭 | 対象 | wprintf() | vwprintf() | wscanf() | vwscanf() |
|---|---|---|---|---|---|
| 標準入出力 | wprintf() | vwprintf() | wscanf() | vwscanf() 1 | |
| f | ストリーム | fwprintf() | vfwprintf() | fwscanf() | vfwscanf() 1 |
| s | 文字列 | swprintf() | vswprintf() | swscanf() | vswscanf() 1 |
プレフィックス v を持つ wprintf() 系関数や wscanf() 系関数は、引数リストではなく引数リストへのポインタを受け取ります。可変個数引数を利用する関数の中で利用されます。
文字列数値変換 (stdlib.h)
同等の 1 バイト文字用関数が stdlib.h にあります。str~() のワイド文字版です。
| long | unsigned long |
long long | unsigned long long |
機能 |
|---|---|---|---|---|
| wcstol() | wcstoul() | wcstoll() 1 | wcstoull() 1 | ワイド文字列を指定された基数で 整数型の値に変換します。 |
| double | float | long double | 機能 |
|---|---|---|---|
| wcstod() | wcstof() 1 | wcstold() 1 | ワイド文字列を実数型の値に変換します。 |
マルチバイト文字・ワイド文字操作 (stdlib.h)
| 名前 | 機能 |
|---|---|
| btowc() | 指定された文字のワイド文字表現を返します。 |
| mbsinit() | mbstate_t の状態を調べます。 |
| wctob() | 指定されたワイド文字の 1 バイト表現を返します。 |
同等の 1 バイト文字用関数が stdlib.h にあります。
| 名前 | 機能 |
|---|---|
| mbrlen() | マルチバイト文字の長さを判定します。 |
| mbrstowcs() | マルチバイト文字列を mbstate_t に変換します。 |
| mbrtowc() | マルチバイト文字を mbstate_t コードに変換します。 |
| wcrstombs() | mbstate_t をマルチバイト文字列に変換します。 |
| wcrtomb() | mbstate_t コードをマルチバイト文字に変換します。 |
メモリ (string.h)
同等の 1 バイト文字用関数が string.h にあります。
| 名前 | 機能 |
|---|---|
| wmemchr() | n バイト内でワイド文字 c を検索します。 |
| wmemcmp() | 2 つのブロックをちょうど n バイトまで比較します。 |
| wmemcpy() | n バイトのブロックをコピーします。 |
| wmemmove() | n バイトのブロックをコピーします。 |
| wmemset() | n バイトのメモリブロックをバイト c に設定します。 |
文字列 (string.h)
同等の 1 バイト文字用関数が string.h にあります。str~() のワイド文字版です。
| 名前 | 機能 |
|---|---|
| wcscat() | ワイド文字列を別のワイド文字列に追加します。 |
| wcschr() | ワイド文字列をスキャンして,指定された文字が最初に出現する箇所を検索します。 |
| wcscmp() | ワイド文字列を別のワイド文字列と比較します。 |
| wcscoll() | 2 つのワイド文字列を比較します。 |
| wcscpy() | ワイド文字列を別のワイド文字列にコピーします。 |
| wcscspn() | ワイド文字列をスキャンして、指定されたワイド文字列内の文字をまったく含まない先頭部分を検索します。 |
| wcserror() | エラーメッセージワイド文字列へのポインタを返します。 |
| wcslen() | ワイド文字列の長さを計算します。 |
| wcsncat() | 一方のワイド文字列の一部をもう一方のワイド文字列に付加します。 |
| wcsncmp() | ワイド文字列の一部を別のワイド文字列の一部と比較します。 |
| wcsncpy() | ワイド文字列から別のワイド文字列に指定されたバイト数をコピーします。必要であれば、切り捨てまたはパディングを行います。 |
| wcspbrk() | ワイド文字列をスキャンして、指定されたワイド文字列内のいずれかの文字が最初に出現する箇所を検索します。 |
| wcsrchr() | ワイド文字列をスキャンして、指定された文字が最後に出現する箇所を検索します。 |
| wcsspn() | ワイド文字列をスキャンして、指定されたワイド文字列内の文字からなる先頭部分を検索します。 |
| wcsstr() | ワイド文字列をスキャンして、指定された部分ワイド文字列が出現する箇所を検索します。 |
| wcstok() | ワイド文字列からトークンを検索します。トークンは、2 番めのワイド文字列で定義される区切り文字によって区切られます。 |
| wcsxfrm() | ワイド文字列の一部を指定された照合順序のワイド文字列に変換します。 |
時間 (time.h)
同等の 1 バイト文字用関数が time.h にあります。str~() のワイド文字版です。
| 名前 | 機能 |
|---|---|
| wcsftime() | 出力する時間を書式設定します。 |
資料
- C 言語 / 標準ライブラリ / wchar.h (Wikibooks)
- z/OS C/C++ ランタイム・ライブラリー・リファレンス wchar.h — ISO/C マルチバイト・サポート拡張 (IBM)
- C 言語の標準ヘッダ一覧 wchar.h (C 言語)