C++ WINDOWS下 wchar_t *和char * 相互转化总结篇

说道wchar_t和char两个类型大家都不会陌生

wchar_t:在windows下是Unicode 16编码,也就是俗称宽字节

char:当然就是指一个字节,在windows下面默认是gbk编码的

所以在windows 下 wchar_t 转 char也就是编码转化

直接贴出wchar_t *字符串和char *字符串的集中互转方法

方法一:利用Windows的宏W2A,A2W

    USES_CONVERSION;
    char* test1 = W2A(L"我是宽字节");//转化成默认
    wchar_t* test12 = A2W("我是窄字节");


方法二:利用Windows里的ATL里面的类CW2A和CA2W,在转换时候还可以顺便调整编码,不加第二个参数就是保持GBK不变

    std::string test3 = CW2A(L"中文字符",CP_UTF8);//一般可以加一下第二个参数,顺便切换编码
    std::wstring test4 = CA2W("中文字符");//一般不用加第二个参数


方法三:利用Windows API中的函数 WideCharToMultiByte 和 MultiByteToWideChar ,而且也是可以带自定义编码转换

以下函数用法: CharToWchar可以等效于CW2A,WcharToChar可以等效于CA2W

std::wstring CharToWchar(const char* c,size_t m_encode = CP_ACP)
{
    std::wstring str;
    int len = MultiByteToWideChar(m_encode,c,strlen(c),NULL,0);
    wchar_t*    m_wchar = new wchar_t[len + 1];
    MultiByteToWideChar(m_encode,m_wchar,len);
    m_wchar[len] = '\0';
    str = m_wchar;
    delete m_wchar;
    return str;
}
 
std::string WcharToChar(const wchar_t* wp,size_t m_encode = CP_ACP)
{
    std::string str;
    int len = WideCharToMultiByte(m_encode,wp,wcslen(wp),NULL);
    char    *m_char = new char[len + 1];
    WideCharToMultiByte(m_encode,m_char,len,NULL);
    m_char[len] = '\0';
    str = m_char;
    delete m_char;
    return str;
}


方法四:将使用标准C的mbstowcs方法和wcstombs方法,且配合标准C的setlocale方法,这也是利用标准库跨平台的做法,
但是过程没法直接转成自定义的编码,需要额外转码。所以在Windows平台开发的话不推荐。

注意:方法四将留在后面的blog和iconv库一起作为笔记

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐