马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 fresh_python 于 2020-11-13 08:49 编辑
当拷贝或连接的中文字符数过多的时候,会出现字数不匹配的问题
代码:#include <stdio.h>
#define MAX 1024
int main()
{
char str1[MAX];
char str2[MAX];
char *target1 = str1;
char *target2 = str2;
char ch;
int n;
printf("请输入一个字符串到 str1 中:");
fgets(str1, MAX, stdin);
printf("请输入需要拷贝的字符个数:");
scanf("%d", &n);
printf("开始拷贝 str1 的内容到 str2 中...\n");
while (n--)
{
ch = *target2++ = *target1++;
if (ch == '\0')
{
break;
}
if ((int)ch < 0)
{
*target2++ = *target1++;
*target2++ = *target1++;
}
}
*target2 = '\0';
printf("拷贝完毕!\n");
printf("现在,str2 中的内容是:%s\n", str2);
return 0;
}
运行结果:请输入一个字符串到 str1 中:我爱鱼C工作室
请输入需要拷贝的字符个数:5
开始拷贝 str1 的内容到 str2 中...
拷贝完毕!
现在,str2 中的内容是:我爱鱼C工作室
--------------------------------
Process exited after 35.77 seconds with return value 0
请按任意键继续. . .
哪位大神提供一下解决方法
第一、你帖子不应该发在投诉建议区,应该发到对应的板块中去。
第二、这是编码问题,这个程序是针对utf-8编码的。因为在utf-8编码中,汉字是三个字节,所以在判断是汉字之后,会在第32和33行再进行两次拷贝。但若是GBK编码,那么汉字是两个字节,就需要把32或33行删掉一行。你的编译器估计是gbk编码,你把这里删掉一行,试一下。应该就不会出错了。
我爱鱼C工作室 这句话刚好是前面三个汉字,后面三个汉字,若是GBK编码,那么就会把前三个汉字认为是两个汉字,后面三个汉字认为是两个汉字,这样就刚好是5个了。。。。
|