char与wchar_t相互转换

本文介绍了如何在C++中进行宽字符(wchar_t)与窄字符(char)之间的转换,包括wchar_t类型初始化,以及wchar_t*和char*之间的相互转换,并提供了相应的测试代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、wchar类型初始化

wchar_t* wc = L"这是 wchar 测试";

2、wchar_t* 转 char*

char * wchar2char(const wchar_t* wchar )
{
    char * m_char;    
    int len= WideCharToMultiByte( CP_ACP ,0,wchar ,wcslen( wchar ), NULL,0, NULL ,NULL );    
    m_char= new char[len+1];     
    WideCharToMultiByte( CP_ACP ,0,wchar ,wcslen( wchar ),m_char,len, NULL ,NULL );     
    m_char[len]= '\0';     
    return m_char; 
}

3、char* 转 wchar_t*

wchar_t * char2wchar(const char* cchar) 
{     
    wchar_t *m_wchar;    
    int len = MultiByteToWideChar( CP_ACP ,0,cchar ,strlen( cchar), NULL,0);     
    m_wchar= new wchar_t[len+1];     
    MultiByteToWideChar( CP_ACP ,0,cchar,strlen( cchar),m_wchar,len);     
    m_wchar[len]= '\0' ;    
    return m_wchar; 
} 

测试代码:

#include <iostream>
#include <tchar.h>
#include <Windows.h>

using namespace std;

char * wchar2char(const wchar_t* wchar )
{
    char * m_char;    
    int len= WideCharToMultiByte( CP_ACP ,0,wchar ,wcslen( wchar ), NULL,0, NULL ,NULL );    
    m_char= new char[len+1];     
    WideCharToMultiByte( CP_ACP ,0,wchar ,wcslen( wchar ),m_char,len, NULL ,NULL );     
    m_char[len]= '\0';     
    return m_char; 
}

wchar_t * char2wchar(const char* cchar) 
{     
    wchar_t *m_wchar;    
    int len = MultiByteToWideChar( CP_ACP ,0,cchar ,strlen( cchar), NULL,0);     
    m_wchar= new wchar_t[len+1];     
    MultiByteToWideChar( CP_ACP ,0,cchar,strlen( cchar),m_wchar,len);     
    m_wchar[len]= '\0' ;    
    return m_wchar; 
} 


int main()
{
    wchar_t* wc = L"这是 wchar 测试";
    char* c = wchar2char(wc);
    wchar_t* wc2 = char2wchar(c);
    char* c2 = wchar2char(wc2);

    cout << "c: " << c << endl;
    cout << "c2: " << c2 << endl;
    getchar();
    return 0;
}

`wchar_t``wstring`在C++中用于存储宽字符,通常用来支持多字节字符集(如Unicode),以便更好地表示非ASCII字符,如汉字其他国际字符。它们之间有以下相互关系转化: 1. `string`到`char`: 如果要从`string`转换为单字节字符`char`,需要逐个字符处理[^1],因为`char`通常不支持宽字符。 ```cpp std::string str = L"你好"; char single_char[] = ""; for (auto c : str) single_char.push_back(c); // 将宽字符逐个添加到char数组 ``` 2. `char`到`wstring`: 反向过程也需要逐个字符处理,但会自动创建对应的宽字符。 ```cpp const char* char_str = "你好"; wstring wide_str; for (auto c : char_str) wide_str += static_cast<wchar_t>(c); ``` 3. `wstring`到`wchar_t`: 直接转换,因为两者都是宽字符类型。 ```cpp wstring wide_str = L"你好"; wchar_t wide_chars[wide_str.size()]; memcpy(wide_chars, wide_str.c_str(), sizeof(wide_chars)); ``` 4. `wchar_t`到`wstring`: 类似于`string`到`char`,需要逐个复制。 ```cpp wchar_t wide_chars[] = {L'\u4f60', L'\u597d'}; wstring wide_str(wide_chars, sizeof(wide_chars) / sizeof(wide_chars[0])); ``` 5. `wstring`转`string`: 使用`wstring_convert`辅助类[^2]或`utf8`编码实现。 ```cpp wstring wstr = L"你好"; std::wstring_convert<std::codecvt_utf8<wchar_t>> converter; std::string utf8_str = converter.to_bytes(wstr); ``` 6. `string`转`wstring`: 相反的过程,使用`wstring_convert`或UTF-16编码。 ```cpp std::string str = "你好"; std::wstring_convert<std::codecvt_utf8<wchar_t>> converter; wstring wstr = converter.from_bytes(str); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值