トップページ – C言語編 – 標準ライブラリのリファレンス(名前順)
トップページ – C言語編 – 標準ライブラリのリファレンス(ヘッダ別)
概要 |
ワイド文字をマルチバイト文字列に変換する。 |
|
ヘッダ | ||
形式 |
size_t wcrtomb(char* restrict s, const wchar_t w, mbstate_t* restrict ps); |
|
引数 |
s |
変換結果を受け取るメモリアドレス。最低でも MB_CUR_MAX以上の要素数が必要。 |
w |
変換対象のワイド文字。 |
|
ps |
変換状態を管理するオブジェクトへのポインタ。またはヌルポインタ。 |
|
戻り値 |
引数w がマルチバイト文字に変換可能であれば、引数s が指す先へ格納されたマルチバイト文字のバイト数を返す。変換可能でなければ -1 を size_t型にキャストした値を返す。 返される大きさはつねに、MB_CUR_MAX 以下である。 |
|
詳細 |
mbstate_t型の引数が追加されていることを除けば、wctomb関数と同じことを行う関数である。戻り値の内容は異なる。 引数s
がヌルポインタの場合、 ワイド文字を、対応するマルチバイト文字のバイト列へ変換する。文字数としては、いずれにしても1文字であるが、マルチバイト文字としては何バイト必要とするか分からないので、char型の配列で受け取る。 引数w にヌル文字を指定した場合、mbstate_t オブジェクトの変換状態が初期状態に戻される。 変換結果が正しいワイド文字にならない場合、表現形式エラーが発生し、errno に EILSEQ が格納される。 この関数は、ロケールの LC_CTYPEカテゴリの影響を受ける。 |
|
注意 |
あくまで文字の変換なので、末尾に終端文字(L’\0’) は付加されない。 |
|
使用例 |
実行結果:
|
|
関連 |
mbstate_t型の引数を伴わない wctomb関数がある。 |
|
解説章 |
本ページはアフィリエイトプログラムによる収益を得ています。
以下のリンクから商品を購入されると、Programming Place
管理者に紹介料が支払われています。
()
の前後の空白の空け方)(
の直後、)
の直前に空白を入れない)return 0;
を削除(C言語編全体でのコードの統一)新規作成。
Programming Place Plus のトップページへ
はてなブックマーク に保存 | Pocket に保存 | Facebook でシェア |
X で ポスト/フォロー | LINE で送る | noteで書く |
RSS | 管理者情報 | プライバシーポリシー |