Provided by: manpages-ja-dev_0.5.0.0.20210215+dfsg-1_all bug

名前

       mblen - 次のマルチバイト文字のバイト数を返す

書式

       #include <stdlib.h>

       int mblen(const char *s, size_t n);

説明

       s が NULL でなければ、 mblen()  関数は s から始まる最大 n バイトのマルチバイト文字列を検査
       して、 次の完全なマルチバイト文字を取り出す。これには mblen()   関数のみが使用する静的で名
       前のないシフト状態が使用される。 マルチバイト文字がヌルワイド文字でなければ s から消費され
       る バイト数を返す。マルチバイト文字がヌルワイド文字ならば 0 を返す。

       s から始まる n バイトが完全なマルチバイト文字を含んで いなければ、  mblen()   は  -1  を返
       す。マルチバイト文字列 に冗長なシフトシーケンスが含まれていると、 nMB_CUR_MAX 以上の場
       合にも このようなことが起こりえる。

       s から始まるマルチバイト文字列が次の完全な文字の前に  不正なマルチバイト列を含んでいる場合
       にも、 mblen()  は -1 を返す。

       s  が NULL ならば、 mblen()  関数はこの関数のみが 使用するシフト状態を初期化状態に戻し、シ
       フト状態を使用した文字符号の場合に  はゼロ以外を、文字符号がシフト状態を持たない場合にはゼ
       ロを返す。

返り値

       mblen()   関数は s から始まるマルチバイト列を検査して ヌルワイド文字以外を確認した場合には
       そのバイト数を返す。 ヌルワイド文字を確認した場合にはゼロを返す。不正なマルチバイト列に 遭
       遇した場合や完全なマルチバイト文字を解析できなかった場合には -1 を返す。

属性

   マルチスレッディング (pthreads(7) 参照)
       mblen() 関数はスレッドセーフではない。

準拠

       C99.

注意

       mblen()  の動作は現在のロケールの LC_CTYPE カテゴリーに依存している。

       mbrlen(3)  関数は同じ機能のより良いインターフェースを提供する。

関連項目

       mbrlen(3)

この文書について

       この  man ページは Linux man-pages プロジェクトのリリース 3.79 の一部 である。プロジェクト
       の説明とバグ報告に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。