在网络通讯中常使用Unicode编码和utf8编码传输数据
utf8是为服务Unicode的一种可变长度字符编码,它的优势在于对ascii完全兼容,ascii在utf8编码为一个字节,在内存上与ascii编码完全相同。
utf16编码一个字符需要2或者4个字节(在windows下unicode编码就是指UTF16)
//转换为c字符串的一种方法
std::wstring wstr = L"宽字符串";
const wchar_t* t= wstr.c_str();
int len = wstr.length()*2;
const char* str = (char*)t;
//utf8字符串 转换成unicode
#include <codecvt>//std::codecvt_utf8
#include <locale>// std::wstring_convert
string str = "abc字符串";
std::wstring_convert<std::codecvt_utf8<wchar_t>> conv; //定义一个转换器
wstr = conv.from_bytes(str);