vs错误:使用 简体中文GB2312 编码加载文件时,有些字节已用unicode替换字符替换

这个问题出现的上下文我描述一下:

因为有一些重复性的工作,所以我把代码复制到了记事本里边,然后使用记事本里边的替换功能,接着把记事本里的代码复制粘贴回了visual studio里边。

(我真是傻缺,居然不会用visual studio里边的替换功能)

这样就导致了编码的问题,调试的时候就会出现错误。

修改其实很简单的,首先要定位到是哪一句代码出的问题。


出错的地方会有青色的箭头指出来,这个时候最简单的办法便是在代码编辑框里边把这句代码重新输入一下,问题自然就解决了。

如果整段代码都被污染了,那就只好重新都输入一遍了啦

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
可以使用iconv库中的`iconv()`函数来实现将Unicode编码字节数组和字符串char*之间的转换。 下面是一个将Unicode编码字节数组转换为字符串char*的示例代码: ```c++ #include <iconv.h> #include <string.h> // 将Unicode编码字节数组转换为字符串char* char* unicodeToChar(const char* unicodeBytes, size_t unicodeLen, const char* charSet) { iconv_t cd = iconv_open(charSet, "UCS-2BE"); if (cd == (iconv_t)-1) { return NULL; } char* charStr = new char[unicodeLen * 2 + 1]; memset(charStr, 0, unicodeLen * 2 + 1); size_t inBytesLeft = unicodeLen; size_t outBytesLeft = unicodeLen * 2; char* inBuf = (char*)unicodeBytes; char* outBuf = charStr; if (iconv(cd, &inBuf, &inBytesLeft, &outBuf, &outBytesLeft) == (size_t)-1) { delete[] charStr; iconv_close(cd); return NULL; } iconv_close(cd); return charStr; } ``` 上面的代码中,`unicodeBytes`表示Unicode编码字节数组,`unicodeLen`表示字节数组的长度,`charSet`表示要转换为的字符集,例如UTF-8、GBK等。`iconv_open()`函数打开一个iconv转换描述符,`iconv()`函数进行转换,`iconv_close()`函数关闭iconv转换描述符。在转换完成之后,将转换后的字符串char*返回即可。 下面是一个将字符串char*转换为Unicode编码字节数组的示例代码: ```c++ #include <iconv.h> #include <string.h> // 将字符串char*转换为Unicode编码字节数组 char* charToUnicode(const char* charStr, const char* charSet, size_t* unicodeLen) { iconv_t cd = iconv_open("UCS-2BE", charSet); if (cd == (iconv_t)-1) { return NULL; } size_t charLen = strlen(charStr); size_t unicodeBytesLen = charLen * 2; char* unicodeBytes = new char[unicodeBytesLen]; memset(unicodeBytes, 0, unicodeBytesLen); size_t inBytesLeft = charLen; size_t outBytesLeft = unicodeBytesLen; char* inBuf = (char*)charStr; char* outBuf = unicodeBytes; if (iconv(cd, &inBuf, &inBytesLeft, &outBuf, &outBytesLeft) == (size_t)-1) { delete[] unicodeBytes; iconv_close(cd); return NULL; } iconv_close(cd); *unicodeLen = unicodeBytesLen - outBytesLeft; return unicodeBytes; } ``` 上面的代码中,`charStr`表示要转换的字符串char*,`charSet`表示该字符串的字符集,例如UTF-8、GBK等。`iconv_open()`函数打开一个iconv转换描述符,`iconv()`函数进行转换,`iconv_close()`函数关闭iconv转换描述符。在转换完成之后,将转换后的Unicode编码字节数组返回,并将转换后的字节数组的长度保存到`unicodeLen`中。 注意,在使用完毕后要记得释放动态分配的内存。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值