wchar_t型とchar型の相互変換
2011/06/24
wchar_t型文字列とchar型文字列を相互変換してみます。
◆環境
OS |
Windows XP Professional Version 2002 Service Pack 3 |
VC |
Microsoft Visual C++ 2008 91179-136-7480673-60943 |
変換関数は以下のものを使います。
wchar_t -> char | wcstombs_s |
char -> wchar_t | mbstowcs_s |
wchartToChar
|
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:
41:
42:
43:
44:
45:
46:
47:
48:
49:
50:
51:
52:
53:
54:
55:
56:
57:
58:
59:
60:
61:
62:
63:
64:
65:
66:
67:
68:
69:
70:
71:
72:
73:
74:
75:
76:
77:
78:
79:
80:
81:
82:
83:
84:
85:
86:
87:
88:
89:
90:
91:
92:
93:
94:
95:
96:
97:
98:
99:
100:
101:
102:
103:
104:
105:
106:
107:
108:
109:
110:
111:
112:
113:
114:
115:
116:
117:
118:
119:
120:
121:
122:
123:
124:
125:
126:
|
// wchartToChar.cpp : コンソール アプリケーションのエントリ
// ポイントを定義します。
//
#include "stdafx.h"
#include <stdlib.h> // wcstombs_s
#include <locale.h> // setlocale
#include <string.h> // strlen
int wchartToChar ( const wchar_t* pSrc
, char* pDest
, const size_t iDestSize
);
int charToWchart ( const char* pSrc
, wchar_t* pDest
, const size_t sDestSize
);
int _tmain( int argc, _TCHAR* argv[] )
{
// ロケール指定
setlocale( LC_ALL, "Japanese" );
wchar_t* wcBuf = L"wchar_t メッセージ";
printf( "wchar_t:[%S] len:%d byte:%d\n"
, wcBuf
, wcslen( wcBuf )
, sizeof( wcBuf )
);
// %sじゃダメ
// wchar_t* -> char*
char cBuf[(13+1)*2];
wchartToChar( wcBuf, cBuf, sizeof( cBuf ) );
printf( "char :[%s] len:%d byte:%d\n"
, cBuf
, strlen( cBuf )
, sizeof( cBuf )
);
// char* -> wchar_t*
wchar_t wcBuf2[13+1];
charToWchart( cBuf, wcBuf2, sizeof( wcBuf2 ) );
printf( "wchar_t:[%S] len:%d byte:%d\n"
, wcBuf2
, wcslen( wcBuf2 )
, sizeof( wcBuf2 )
);
getchar();
return 0;
}
//==============================================================
// [概要]
// wchar_t* から char* への変換を行う
// [引数]
// pSrc const wchar_t* 変換するwchar_t型の文字列。
// pDest char* 変換結果のchar型文字列。
// sDestSize const size_t pDestのサイズ
// [戻り値]
// int 0:正常,1:異常
//==============================================================
int wchartToChar ( const wchar_t* pSrc
, char* pDest
, const size_t sDestSize
)
{
size_t iReturnValue;
errno_t ret = wcstombs_s( &iReturnValue
, pDest
, sDestSize
, pSrc
, _TRUNCATE
);
if ( ret != 0 )
{
printf( "wcstombs_s error!! ret=%d\n", ret );
return 1;
}
printf( "wcstombs_s return value:%d\n"
, iReturnValue
);
return 0;
}
//==============================================================
// [概要]
// char* から wchar_t* への変換を行う
// [引数]
// pSrc const char* 変換するchar型の文字列。
// pDest wchar_t* 変換結果のwchar_t型文字列。
// sDestSize const size_t pDestのサイズ
// [戻り値]
// int 0:正常,1:異常
//==============================================================
int charToWchart ( const char* pSrc
, wchar_t* pDest
, const size_t sDestSize
)
{
size_t iReturnValue;
errno_t ret = mbstowcs_s( &iReturnValue
, pDest
, sDestSize
, pSrc
, _TRUNCATE
);
if ( ret != 0 )
{
printf( "mbstowcs_s error!! ret=%d\n", ret );
return 1;
}
printf( "wcstombs_s return value:%d\n"
, iReturnValue
);
return 0;
}
|
|
実行してみます。
wchar_t:[wchar_t メッセージ] len:13 byte:4
wcstombs_s return value:19
char :[wchar_t メッセージ] len:18 byte:28
mbstowcs_s error!! ret=42
wchar_t:[] len:0 byte:28
2つ問題が発生しました。
- mbstowcs_s関数でエラー発生。復帰値は42。
- 最後にエラー発生。Stack around the variable 'cBuf' was corrupted.
mbstowcs_s関数のエラーの原因を探る為、エラーコードの判定文を追加しました。
wchartToChar
|
94:
95:
96:
97:
98:
99:
100:
101:
102:
103:
104:
105:
106:
107:
108:
109:
110:
111:
112:
113:
114:
115:
116:
117:
118:
119:
120:
121:
122:
123:
124:
125:
126:
127:
128:
129:
130:
131:
132:
133:
134:
135:
136:
|
//==============================================================
// [概要]
// char* から wchar_t* への変換を行う
// [引数]
// pSrc const char* 変換するchar型の文字列。
// pDest wchar_t* 変換結果のwchar_t型文字列。
// sDestSize const size_t pDestのサイズ
// [戻り値]
// int 0:正常,1:異常
//==============================================================
int charToWchart ( const char* pSrc
, wchar_t* pDest
, const size_t sDestSize
)
{
size_t iReturnValue;
errno_t ret = mbstowcs_s( &iReturnValue
, pDest
, sDestSize
, pSrc
, _TRUNCATE
);
if ( ret != 0 )
{
printf( "mbstowcs_s error!! ret=" );
switch( ret )
{
case EINVAL: printf( "EINVAL\n" ); break;
case ERANGE: printf( "ERANGE\n" ); break;
case EILSEQ: printf( "EILSEQ\n" ); break;
default:
printf( "other[%d]\n", ret );
break;
}
return 1;
}
printf( "wcstombs_s return value:%d\n"
, iReturnValue
);
return 0;
}
|
|
実行します。
wchar_t:[wchar_t メッセージ] len:13 byte:4
wcstombs_s return value:19
char :[wchar_t メッセージ] len:18 byte:28
mbstowcs_s error!! ret=EILSEQ
wchar_t:[] len:0 byte:28
mbstowcs_s関数のエラーはEILSEQでした。
EILSEQは無効なマルチバイト文字を検出した時に返るようです。
色々試した結果、以下のようにしたら動作しました。
- mbstowcs_sへ渡す文字列をcBufから固定文字列にした。
- mbstowcs_sへ渡す、変換後の文字列を格納領域を配列からnewで確保するようにした。
wchartToChar
|
44:
45:
46:
47:
48:
49:
50:
51:
52:
|
// char* -> wchar_t*
wchar_t* wcBuf2 = new wchar_t[13+1];
charToWchart( "wchar_t メッセージ", wcBuf2, 13+1 );
printf( "wchar_t:[%S] len:%d byte:%d\n"
, wcBuf2
, wcslen( wcBuf2 )
, sizeof( wcBuf2 )
);
delete wcBuf2;
|
|
実行してみます。
wchar_t:[wchar_t メッセージ] len:13 byte:4
wcstombs_s return value:19
char :[wchar_t メッセージ] len:18 byte:28
wcstombs_s return value:14
wchar_t:[wchar_t メッセージ] len:13 byte:4
エラーは出なくなりました。
エラー原因はmbstowcs_s関数へ渡す第三引数が「文字数」になっていなかったことのようです。>> wchar_t型とchar型の相互変換A
▲ PageTop ■ Home
Copyright (C) 2012 ymlib.com