作者:Chloemw | 2023-09-06 09:52
我正在寻找一种方法,或用于将std :: string转换为LPCWSTR的代码片段
1> Toran Billup..:
感谢MSDN文章的链接.这正是我所寻找的.
std::wstring s2ws(const std::string& s)
{
int len;
int slength = (int)s.length() + 1;
len = MultiByteToWideChar(CP_ACP, 0, s.c_str(), slength, 0, 0);
wchar_t* buf = new wchar_t[len];
MultiByteToWideChar(CP_ACP, 0, s.c_str(), slength, buf, len);
std::wstring r(buf);
delete[] buf;
return r;
}
std::wstring stemp = s2ws(myString);
LPCWSTR result = stemp.c_str();
理由#233关于为什么c ++会让我感到厌烦.为了简单的字符串转换,有10行代码= /
如果你使用std :: vector
为buf创建存储,那么如果有什么抛出异常,你的临时缓冲区将被释放.
(发现这个问题随机浏览;自从我做C++以来已经很久了.)所以标准库没有std :: string - > std :: wstring转换?这看起来很奇怪; 有充分的理由吗?
@CJBrew:对于每个问题都有一个解决方案,那就是干净,优雅和错误.您的输入基于您的输入仅包含ASCII(**而非**ANSI)字符的假设.
或者只是说wstring ws(s.begin(),s.end())......?
2> 小智..:
解决方案实际上比任何其他建议容易得多:
std::wstring stemp = std::wstring(s.begin(), s.end());
LPCWSTR sw = stemp.c_str();
最重要的是,它与平台无关.h2h :)
仅当所有字符都是单字节时才有效,即ASCII或[ISO-8859-1](http://en.wikipedia.org/wiki/ISO-8859-1).任何多字节都会失败,包括UTF-8.
主啊,所有的赞成都是什么?这个答案有效,**有时**,仅凭巧合.它完全忽略了**编码**.你不能简单地扩大一个狭窄的角色,并希望它神奇地变成代表相同代码点的宽字符.它是"reinterpret_cast"的道德等价物.**此代码不起作用.不使用.**.
对不起Benny,但这对我不起作用,Toran自己的解决方案看起来确实很好(但是......很多!).
@nik:在Windows上,通常将char编码为ANSI。使用ANSI编码时,将使用当前活动的代码页解释值128到255。将这些值推入wchar_t(在Windows上为UTF-16编码)将不会产生所需的结果。如果要精确,这在50%的情况下都有效。考虑到DBCS字符编码,该百分比进一步降低。
3> 17 of 26..:
如果您在ATL/MFC环境中,则可以使用ATL转换宏:
#include
#include
. . .
string myStr("My string");
CA2W unicodeStr(myStr);
然后,您可以将unicodeStr用作LPCWSTR.unicode字符串的内存在堆栈上创建并释放,然后执行unicodeStr的析构函数.