65,187
社区成员




#include "codechange.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <Windows.h>
#include <locale.h>
wchar_t *ANSITOUnicode(const char* str){
int textlen = 0;
wchar_t *result = NULL;
textlen = MultiByteToWideChar(CP_ACP,0,str,-1,NULL,0);
result = (wchar_t*)malloc((textlen+1)*sizeof(wchar_t));
memset(result,0,(textlen+1)*sizeof(wchar_t));
MultiByteToWideChar(CP_ACP,0,str,-1,(LPWSTR)result,textlen);
return result;
}
char *UnicodeToANSI(const wchar_t *str){
char *result = NULL;
int textlen = 0;
textlen = WideCharToMultiByte(CP_ACP,0,str,-1,NULL,0,NULL,NULL);
result = (char*)malloc((textlen+1)*sizeof(char));
memset(result,0,sizeof(char)*(textlen+1));
WideCharToMultiByte(CP_ACP,0,str,-1,result,textlen,NULL,NULL);
return result;
}
wchar_t *Utf8ToUnicode(const char* str){
int textlen = 0;
wchar_t *result = NULL;
textlen = MultiByteToWideChar(CP_UTF8,0,str,-1,NULL,0);
result = (wchar_t *)malloc((textlen+1)*sizeof(wchar_t));
memset(result,0,(textlen+1)*sizeof(wchar_t));
MultiByteToWideChar(CP_UTF8,0,str,-1,(LPWSTR)result,textlen);
return result;
}
char* UnicodeToUTF8(const wchar_t* str){
char *result = NULL;
int textlen = 0;
textlen = WideCharToMultiByte(CP_UTF8,0,str,-1,NULL,0,NULL,NULL);
result = (char*)malloc((textlen+1)*sizeof(char));
memset(result,0,sizeof(char)*(textlen+1));
WideCharToMultiByte(CP_UTF8,0,str,-1,result,textlen,NULL,NULL);
return result;
}
wchar_t* m2w(const char* mbs){
int len = 0;
wchar_t* buf;
len = mbstowcs(NULL,mbs,0);
if (len == 0)
return NULL;
buf = (wchar_t*)malloc(sizeof(wchar_t)*(len+1));
memset(buf,0,sizeof(wchar_t*)*(len+1));
len = mbstowcs(buf,mbs,len+1);
return buf;
}
char* ANSIToUTF8(const char* str){
return UnicodeToUTF8(ANSITOUnicode(str));
}
char* UTF8ToANSI(const char* str){
return UnicodeToANSI(Utf8ToUnicode(str));
}
// 功能: ANSI字符串转换为WideChar
// 参数:[in]szANSI - 被转换的ANSI字符串
// 返回值: wchar_t* 转换后的widechar字符串指针,调用者需要delete
wchar_t* CUtility::ANSIToWideChar( const char* szANSI )
{
ASSERT(szANSI != NULL);
int unicodeLen = ::MultiByteToWideChar(CP_ACP, 0, szANSI, -1, NULL, 0);
wchar_t* pUnicode = new wchar_t[unicodeLen+1];
memset(pUnicode, 0x00, sizeof(wchar_t)*(unicodeLen+1));
::MultiByteToWideChar(CP_ACP, 0, szANSI, -1, pUnicode, unicodeLen);
return pUnicode;
}
// 功能: WideChar字符串转换为ANSI
// 参数:[in]szWidechar - 被转换的WideChar字符串
// 返回值: char* 转换后的ANSI字符串指针,调用者需要delete
char* CUtility::WideCharToANSI( const wchar_t* szWidechar )
{
ASSERT(szWidechar != NULL);
int widecharLen = ::WideCharToMultiByte(CP_ACP, 0, szWidechar, -1, NULL, 0, NULL, NULL);
char* pAnsi = new char[widecharLen+1];
memset(pAnsi, 0x00, widecharLen+1);
::WideCharToMultiByte(CP_ACP, 0, szWidechar, -1, pAnsi, widecharLen, NULL, NULL);
return pAnsi;
}
多字节和Unicode的相互转换,供参考