トップページ – C言語編 – 標準ライブラリのリファレンス(名前順)
トップページ – C言語編 – 標準ライブラリのリファレンス(ヘッダ別)
概要 |
マルチバイト文字をワイド文字に変換する。 |
|
ヘッダ | ||
形式 |
int mbtowc(wchar_t* restrict ws, const char* restrict s, size_t n); |
|
引数 |
ws |
変換結果を受け取るメモリアドレス。受け取らない場合はヌルポインタでも良い。 |
s |
変換対象のマルチバイト文字列。 |
|
n |
変換する最大バイト数。 |
|
戻り値 |
引数s がヌルポインタでない場合は、引数s が指すバイトから、引数n
で指定したバイト数だけを調べ、それがマルチバイト文字として有効なバイト列であれば、マルチバイト文字を構成するバイト数を返す。有効なバイト列でなければ
-1 を返す。なお、引数s がヌル文字(‘\0’) を指している場合は 0
を返す。 |
|
詳細 |
バイト列がマルチバイト文字を構成しているものと考え、引数 n
で指定したバイト数分だけ調べる。マルチバイト文字が必要とする可能性がある最大バイト数は、ロケールによって異なるので、引数n
には MB_CUR_MAX
を指定することが多い。調べた範囲が、有効なマルチバイト文字を構成していれば、それに対応するワイド文字の値を決定し、その値を引数ws
で指定した位置へ格納する。引数ws
がヌルポインタの場合は格納せず処理を終える。 |
|
注意 |
あくまで文字の変換なので、末尾に終端文字(L’\0’) は付加されない。 |
|
使用例 |
実行結果:
|
|
関連 |
逆方向の変換であるワイド文字からマルチバイト文字列への変換は、wctomb関数で行える。なお、終端文字のあるマルチバイト文字列からワイド文字列への変換は、mbstowcs関数で行える。 |
|
解説章 |
本ページはアフィリエイトプログラムによる収益を得ています。
以下のリンクから商品を購入されると、Programming Place
管理者に紹介料が支払われています。
()
の前後の空白の空け方)(
の直後、)
の直前に空白を入れない)return 0;
を削除(C言語編全体でのコードの統一)解説中で C95 を(C89 に対して)特別扱いしないように修正。そもそもC言語編は C95ベースなので、余計な説明は省く。
「NULL」という表記を「ヌルポインタ」に修正。
全体的に文章を見直し修正。
新規作成。
Programming Place Plus のトップページへ
はてなブックマーク に保存 | Pocket に保存 | Facebook でシェア |
X で ポスト/フォロー | LINE で送る | noteで書く |
RSS | 管理者情報 | プライバシーポリシー |