書式
#include <stdlib.h>
int wctomb(char *s, wchar_t wc);
説明
s が NULL でなければ、 wctomb() 関数はワイド文字 wc を マルチバイト表現に変換して s の指す文字配列に格納する。 同時に wctomb 関数のみが使用する静的で名前のないシフト状態を更新する。 この関数はマルチバイト表現の長さ、すなわち s に書き込まれた バイト数を返す。プログラマーは s に少なくとも MB_CUR_MAX バイトの空きがあることを保証しなければならない。
s が NULL ならば、 wctomb() 関数は自分のみが使用するシフト状態を 初期状態に戻して、文字符号がシフト状態に依存しているならばゼロ以外を シフト状態に依存しない場合にはゼロを返す。
返り値
s が NULL でない場合 wctomb() 関数はバイト配列 s に 書き込まれたバイト数を返す。wc が(現在のロケールにおいて) マルチバイト列で表現できない場合には -1 を返す。s が NULL の場合 wctomb() 関数は文字符号がシフト状態に 依存している場合にはゼロ以外、シフト状態に依存しない場合はゼロを返す。
属性
マルチスレッディング (pthreads(7) 参照)
wctomb() 関数はスレッドセーフではない。準拠
C99.注意
wctomb() 関数の動作は現在のロケールの LC_CTYPE カテゴリに依存している。wcrtomb(3) 関数は同じ機能のより良いインタフェースを提供する。
この文書について
この man ページは Linux man-pages プロジェクトのリリース 3.65 の一部 である。プロジェクトの説明とバグ報告に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。