鱼C论坛

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

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

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

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

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

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

我爱鱼C工作室    这句话刚好是前面三个汉字,后面三个汉字,若是GBK编码,那么就会把前三个汉字认为是两个汉字,后面三个汉字认为是两个汉字,这样就刚好是5个了。。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

我爱鱼C工作室    这句话刚好是前面三个汉字,后面三个汉字,若是GBK编码,那么就会把前三个汉字认为是两个汉字,后面三个汉字认为是两个汉字,这样就刚好是5个了。。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-11-12 16:58:43 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> 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个字节来计算了,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

因为字符串还有一个结束字符'\0'
你可以试一下多个汉字的长度。总是二倍于汉字个数再加1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

好的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-12 17:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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