1、乱码情况
CString strInput = L"学习1";
int len = WideCharToMultiByte(CP_ACP,0,strInput,strInput.GetLength(),NULL,0,NULL,NULL);
char *p = new char[len + 1];
A: WideCharToMultiByte(CP_ACP,0,strInput,strInput.GetLength(),p,len,NULL,NULL);
p[len + 1] = '\0';
这种方式转换后的字符串末尾会乱码,就算末尾赋值为‘\0’依旧是乱码
2、修改方法
将上面标注的A行代码改为:
WideCharToMultiByte(CP_ACP,0,strInput,strInput.GetLength() + 1,p,len + 1,NULL,NULL);
或者改为:
WideCharToMultiByte(CP_ACP,0,strInput,-1,p,len + 1,NULL,NULL);
//第4个参数 为-1时,字符串strInput将被设定为以NULL为结束符的字符串,并且自动计算长度。
3、为什么要这样改?
WideCharToMultiByte(CP_ACP,0,strInput,strInput.GetLength(),p,len,NULL,NULL);
采用这种方式时,strInput结束符不会被转换到p中去,因为strInput.GetLength()不包括结束符
WideCharToMultiByte(CP_ACP,0,strInput,-1,p,len,NULL,NULL);
采用这种方式时,strInput结束符不会被转换到p中去,因为len长度不够放结束符
综上原因,把上面提到的2处参数改为“2、修改方法”里面的那样,就可以去掉末尾的乱码了
以上代码本人亲测