WCSRTOMBS(3) | Linux Programmer's Manual | WCSRTOMBS(3) |
wcsrtombs - ワイド文字文字列をマルチバイト文字列に変換する
#include <wchar.h>
size_t wcsrtombs(char *dest, const wchar_t **src, size_t len, mbstate_t *ps);
dest が NULL でなければ、 wcsrtombs() 関数は ワイド文字文字列 *src を dest が指すマルチバイト文字列 に変換する。最大 len バイトまでが dest に書き込まれる。 シフト状態 *ps は更新される。実際の効果としては、この変換は以下 の動作と同じになる: wcrtomb(dest, *src, ps) を呼び、成功が返ったら、 dest を書き込んだバイト数だけ増やし、*src を 1 増やす。 そして、wcrtomb が成功を返す限りこれを繰り返す。 変換が止まる理由は 3 つ考えられる:
dest が NULL ならば len は無視されて前述のように変換が行わ れるが、変換されたバイトデータはメモリーに書き出されない点と、出力先の長 さの制限がない点が異なる。
上記のいずれの場合も、ps が NULL ならば、wcsrtombs() 関数 だけが知っている静的な匿名の状態がシフト状態の代わりに用いられる。
プログラマは少なくとも len バイトの領域を dest に確保しな ければならない。
wcsrtombs() は、変換して得られたマルチバイト列のバイト数を返す。 これには終端の null バイトは含まれない。 変換できないワイド文字に出会った場合には (size_t) -1 が返され、 errno に EILSEQ が設定される。
この節で使用されている用語の説明については、 attributes(7) を参照。
インターフェース | 属性 | 値 |
wcsrtombs() | Thread safety | MT-Unsafe race:wcsrtombs/!ps |
POSIX.1-2001, POSIX.1-2008, C99.
wcsrtombs() の動作は現在のロケールの LC_CTYPE カテゴリーに依存する。
ps に NULL を渡した際の動作はマルチスレッドセーフでない。
iconv(3), mbsinit(3), wcrtomb(3), wcsnrtombs(3), wcstombs(3)
この man ページは Linux man-pages プロジェクトのリリース 5.10 の一部である。プロジェクトの説明とバグ報告に関する情報は https://www.kernel.org/doc/man-pages/ に書かれている。
2019-03-06 | GNU |