带你学c带你飞,课后题S1E22的动动手代码bug
本帖最后由 fresh_python 于 2020-11-13 08:49 编辑当拷贝或连接的中文字符数过多的时候,会出现字数不匹配的问题
代码:
#include <stdio.h>
#define MAX 1024
int main()
{
char str1;
char str2;
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
请按任意键继续. . .
哪位大神提供一下解决方法{:5_100:}
第一、你帖子不应该发在投诉建议区,应该发到对应的板块中去。
第二、这是编码问题,这个程序是针对utf-8编码的。因为在utf-8编码中,汉字是三个字节,所以在判断是汉字之后,会在第32和33行再进行两次拷贝。但若是GBK编码,那么汉字是两个字节,就需要把32或33行删掉一行。你的编译器估计是gbk编码,你把这里删掉一行,试一下。应该就不会出错了。
我爱鱼C工作室 这句话刚好是前面三个汉字,后面三个汉字,若是GBK编码,那么就会把前三个汉字认为是两个汉字,后面三个汉字认为是两个汉字,这样就刚好是5个了。。。。 @小甲鱼 @不二如是 sunrise085 发表于 2020-11-12 12:43
第一、你帖子不应该发在投诉建议区,应该发到对应的板块中去。
第二、这是编码问题,这个程序是针对utf-8 ...
(1)啊,不好意思,{:5_96:},我会注意这个问题的,
(2)我按照dalao你的方法改了,确实可以,但是为什么我运行int ch_len = sizeof("中")/sizeof(char);得到的ch_len 的值是3呢?? 所以,我就按照3个字节来计算了,{:5_100:} fresh_python 发表于 2020-11-13 08:47
(1)啊,不好意思,,我会注意这个问题的,
(2)我按照dalao你的方法改了,确实可以,但是为 ...
因为字符串还有一个结束字符'\0'
你可以试一下多个汉字的长度。总是二倍于汉字个数再加1 sunrise085 发表于 2020-11-13 14:10
因为字符串还有一个结束字符'\0'
你可以试一下多个汉字的长度。总是二倍于汉字个数再加1
好的
页:
[1]