当前位置:  开发笔记 > 编程语言 > 正文

如何在C++(Unicode)中将std :: string转换为LPCWSTR

如何解决《如何在C++(Unicode)中将std::string转换为LPCWSTR》经验,为你挑选了3个好方法。

我正在寻找一种方法,或用于将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的析构函数.

推荐阅读
Chloemw
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有