|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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个了。。。。
|
|