wchar_t*和string相互转换 unicode 转utf8

在window环境中,可以利用


MultiByteToWideChar();
WideCharToMultiByte();

单字节字符串string转双字节字符串wchar_t*

//不要忘记在使用完wchar_t*后delete[]释放内存
wchar_t *multiByteToWideChar(const string& pKey)
{
	const char* pCStrKey = pKey.c_str();
	//第一次调用返回转换后的字符串长度,用于确认为wchar_t*开辟多大的内存空间
	int pSize = MultiByteToWideChar(CP_OEMCP, 0, pCStrKey, strlen(pCStrKey) + 1, NULL, 0); 
	wchar_t *pWCStrKey = new wchar_t[pSize];
	//第二次调用将单字节字符串转换成双字节字符串
	MultiByteToWideChar(CP_OEMCP, 0, pCStrKey, strlen(pCStrKey) + 1, pWCStrKey, pSize);
	return pWCStrKey;
}

双字节字符串wchar_t*转换成单字节字符串char*或string

//不要忘记使用完char*后delete[]释放内存
char* wideCharToMultiByte(wchar_t* pWCStrKey)
{
	//第一次调用确认转换后单字节字符串的长度,用于开辟空间
	int pSize = WideCharToMultiByte(CP_OEMCP, 0, pWCStrKey, wcslen(pWCStrKey), NULL, 0, NULL, NULL);
	char* pCStrKey = new char[pSize+1];
	//第二次调用将双字节字符串转换成单字节字符串
	WideCharToMultiByte(CP_OEMCP, 0, pWCStrKey, wcslen(pWCStrKey), pCStrKey, pSize, NULL, NULL);
	pCStrKey[pSize] = '\0';
	return pCStrKey;

	//如果想要转换成string,直接赋值即可
	//string pKey = pCStrKey;
}

unicode 转utf8

//不要忘记使用完char*后delete[]释放内存
char * unicodeToUtf8(wchar_t * wszString)
{

	//预转换,得到所需空间的大小,这次用的函数和上面名字相反
	int u8Len = ::WideCharToMultiByte(CP_UTF8, NULL, wszString, wcslen(wszString), NULL, 0, NULL, NULL);
	//同上,分配空间要给'\0'留个空间
	//UTF8虽然是Unicode的压缩形式,但也是多字节字符串,所以可以以char的形式保存
	char* utf8str = new char[u8Len + 1];
	//转换
	//unicode版对应的strlen是wcslen
	int size = wcslen(wszString);
	::WideCharToMultiByte(CP_UTF8, NULL, wszString, wcslen(wszString), utf8str, u8Len, NULL, NULL);
	//最后加上'\0'
	utf8str[u8Len] = '\0';

	return utf8str;
}

 

你可能感兴趣的:(C++)