//在windows与linux系统通过socket的传输数据里,如果传输中文字符,因为windows和linux使用的编码不同,所以需要将windows下的中文编码转换为linux使用的utf8格式的,否则会出现乱码
//m_string是windows下的中文字符串
//utf8_string是返回转换为utf8编码的中文字符串
//slen是utf8_string字符数组的大小
#include
int multichar_2_utf8(const char *m_string,char *utf8_string,int slen)
{
int len=0;
wchar_t *w_string;
//char *utf8_string;
//计算由ansi转换为unicode后,unicode编码的长度
len=multibytetowidechar(cp_acp,0,(char *)m_string, -1, null,0);//cp_acp指示了转换为unicode编码的编码类型
w_string=(wchar_t *)malloc(2*len 2);
memset(w_string,0,2*len 2);
//ansi到unicode转换
multibytetowidechar(cp_acp, 0, (char *)m_string,-1,w_string, len);//cp_acp指示了转换为unicode编码的编码类型
//计算unicode转换为utf8后,utf8编码的长度
//len = widechartomultibyte(cp_utf8, 0, w_string, -1, null, 0, null, null);//cp_utf8指示了unicode转换为的类型
//utf8_string=(char *)malloc(len 1);
// memset(utf8_string, 0, len 1);
//unicode到utf8转换
//widechartomultibyte(cp_utf8, 0, w_string, -1, utf8_string, len, null,null);//cp_utf8指示了unicode转换为的类型
widechartomultibyte(cp_utf8, 0, w_string, -1, utf8_string, slen, null,null);//cp_utf8指示了unicode转换为的类型
free(w_string);
return 0;
}
阅读(3678) | 评论(0) | 转发(0) |