wstring と string の間で変換する必要があります。codecvt ファセットを使用するとうまくいくはずですが、utf-8 ロケールではうまくいかないようです。
私の考えは、utf-8でエンコードされたファイルをcharに読み取ると、1つのutf-8文字が2つの通常の文字に読み取られるということです(これがutf-8の仕組みです)。コードで使用するライブラリの wstring 表現からこの utf-8 文字列を作成したいと思います。
誰もそれを行う方法を知っていますか?
私はすでにこれを試しました:
locale mylocale("cs_CZ.utf-8");
mbstate_t mystate;
wstring mywstring = L"čřžýáí";
const codecvt<wchar_t,char,mbstate_t>& myfacet =
use_facet<codecvt<wchar_t,char,mbstate_t> >(mylocale);
codecvt<wchar_t,char,mbstate_t>::result myresult;
size_t length = mywstring.length();
char* pstr= new char [length+1];
const wchar_t* pwc;
char* pc;
// translate characters:
myresult = myfacet.out (mystate,
mywstring.c_str(), mywstring.c_str()+length+1, pwc,
pstr, pstr+length+1, pc);
if ( myresult == codecvt<wchar_t,char,mbstate_t>::ok )
cout << "Translation successful: " << pstr << endl;
else cout << "failed" << endl;
return 0;
cs_CZ.utf-8 ロケールでは「失敗」を返し、cs_CZ.iso8859-2 ロケールでは正しく機能します。