鱼C论坛

 找回密码
 立即注册
查看: 878|回复: 5

[已解决]带你学c带你飞,课后题S1E22的动动手代码bug

[复制链接]
发表于 2020-11-12 08:29:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 fresh_python 于 2020-11-13 08:49 编辑

当拷贝或连接的中文字符数过多的时候,会出现字数不匹配的问题
代码:
  1. #include <stdio.h>

  2. #define MAX 1024

  3. int main()
  4. {
  5.         char str1[MAX];
  6.         char str2[MAX];

  7.         char *target1 = str1;
  8.         char *target2 = str2;

  9.         char ch;
  10.         int n;

  11.         printf("请输入一个字符串到 str1 中:");
  12.         fgets(str1, MAX, stdin);

  13.         printf("请输入需要拷贝的字符个数:");
  14.         scanf("%d", &n);

  15.         printf("开始拷贝 str1 的内容到 str2 中...\n");
  16.         while (n--)
  17.         {
  18.                ch = *target2++ = *target1++;
  19.                if (ch == '\0')
  20.                {
  21.                        break;
  22.                }
  23.                if ((int)ch < 0)
  24.                {
  25.                        *target2++ = *target1++;
  26.                        *target2++ = *target1++;
  27.                }
  28.         }

  29.         *target2 = '\0';

  30.         printf("拷贝完毕!\n");
  31.         printf("现在,str2 中的内容是:%s\n", str2);

  32.         return 0;
  33. }
复制代码

运行结果:
  1. 请输入一个字符串到 str1 中:我爱鱼C工作室
  2. 请输入需要拷贝的字符个数:5
  3. 开始拷贝 str1 的内容到 str2 中...
  4. 拷贝完毕!
  5. 现在,str2 中的内容是:我爱鱼C工作室

  6. --------------------------------
  7. Process exited after 35.77 seconds with return value 0
  8. 请按任意键继续. . .


复制代码

哪位大神提供一下解决方法
最佳答案
2020-11-12 12:43:06
第一、你帖子不应该发在投诉建议区,应该发到对应的板块中去。
第二、这是编码问题,这个程序是针对utf-8编码的。因为在utf-8编码中,汉字是三个字节,所以在判断是汉字之后,会在第32和33行再进行两次拷贝。但若是GBK编码,那么汉字是两个字节,就需要把32或33行删掉一行。你的编译器估计是gbk编码,你把这里删掉一行,试一下。应该就不会出错了。

我爱鱼C工作室    这句话刚好是前面三个汉字,后面三个汉字,若是GBK编码,那么就会把前三个汉字认为是两个汉字,后面三个汉字认为是两个汉字,这样就刚好是5个了。。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-11-12 12:43:06 | 显示全部楼层    本楼为最佳答案   
第一、你帖子不应该发在投诉建议区,应该发到对应的板块中去。
第二、这是编码问题,这个程序是针对utf-8编码的。因为在utf-8编码中,汉字是三个字节,所以在判断是汉字之后,会在第32和33行再进行两次拷贝。但若是GBK编码,那么汉字是两个字节,就需要把32或33行删掉一行。你的编译器估计是gbk编码,你把这里删掉一行,试一下。应该就不会出错了。

我爱鱼C工作室    这句话刚好是前面三个汉字,后面三个汉字,若是GBK编码,那么就会把前三个汉字认为是两个汉字,后面三个汉字认为是两个汉字,这样就刚好是5个了。。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-11-12 16:58:43 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-13 08:47:54 | 显示全部楼层
sunrise085 发表于 2020-11-12 12:43
第一、你帖子不应该发在投诉建议区,应该发到对应的板块中去。
第二、这是编码问题,这个程序是针对utf-8 ...

(1)啊,不好意思,,我会注意这个问题的,
(2)我按照dalao你的方法改了,确实可以,但是为什么我运行int ch_len = sizeof("中")/sizeof(char);得到的ch_len 的值是3呢?? 所以,我就按照3个字节来计算了,
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-13 14:10:53 | 显示全部楼层
fresh_python 发表于 2020-11-13 08:47
(1)啊,不好意思,,我会注意这个问题的,
(2)我按照dalao你的方法改了,确实可以,但是为 ...

因为字符串还有一个结束字符'\0'
你可以试一下多个汉字的长度。总是二倍于汉字个数再加1
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-15 13:16:08 | 显示全部楼层
sunrise085 发表于 2020-11-13 14:10
因为字符串还有一个结束字符'\0'
你可以试一下多个汉字的长度。总是二倍于汉字个数再加1

好的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-1 10:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表