mbstowcs

多バイト文字列 (multibyte string) をワイド文字列 (wide string) に変換します.

#include <stdlib.h>
size_t mbstowcs(
    wchar_t * restrict pwcs,
    const char * restrict s,
    size_t n
);

mbstowcs 関数は s が指す多バイト文字列を対応するワイド文字列に変換し,n 文字以下のワイド文字列を pwcs が指す配列に格納します. ナル文字 ('\0') に続く多バイト文字は変換されません.(調べることもありません.) ナル文字ナルワイド文字 (null wide character) に変換されます. 領域の重なり合うオブジェクト間でコピーが行われるときの動作は未定義です.

mbstowcs 関数の動作は,その時点のロケール (locale) の LC_CTYPE カテゴリの影響を受けます.

引数

  • pwcs: ワイド文字列を格納する場所
  • s: 変換する多バイト文字列
  • n: 変換する文字列の文字数

戻り値

  • 変換に成功したとき: 変換した文字数 (終端のナルワイド文字は除く)
  • 不正な多バイト文字が含まれているとき: (size_t)(-1)

C言語サンプルプログラム

mbstowcs 関数を使用して多バイト文字列をワイド文字列に変換するサンプルプログラムを以下に示します.

/* header files */
#include <stdio.h>
#include <stdlib.h>
#include <wchar.h>
#include <locale.h>

/* main */
int main(void) {
    wchar_t *pwcs;
    char s[] = "あいうえお";
    int result;

    /* ロケールを変更 */
    setlocale(LC_CTYPE, "JPN");

    result = mbstowcs(pwcs, s, 256);
    if ( result > 0 ) {
        printf("s は正しい多バイト文字列です.\n");
        wprintf(L"pwcs: %s \n", pwcs);

    } else {
        printf("s は正しい多バイト文字を形成していません.\n");

    }

    return EXIT_SUCCESS;
}

実行例

サンプルプログラムの実行結果は以下のようになります.

s は正しい多バイト文字列です.
pwcs: あいうえお 

Cプログラマの必読書

たくさんあるC言語関連の書籍の中でも特に役に立った本です.よかったら参考にしてみてください.

C実践プログラミング 第3版

C言語の実践的参考書.少々値段は張りますが初心者を脱しようとしている人は絶対に読むべきです.
文法だけでなく,コーディングスタイルやデバッグなど文字通り「実践的」なことが書かれているので非常にためになります. オライリーの本は,読みにくい本が多いのですが本書はとても読みやすくオススメです.


C言語ポインタ完全制覇 (標準プログラマーズライブラリ)

ポインタの解説書としては最高の書籍です.
この1冊でポインタを完全に理解することができます.全くの初学者が読むには敷居が高いですが,入門書を読み終えた後に読むと非常に有益です.