鱼C论坛

 找回密码
 立即注册
查看: 944|回复: 7

[已解决]C语言!字符输入问题!

[复制链接]
发表于 2020-12-27 17:12:55 | 显示全部楼层 |阅读模式

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

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

x
#include<stdio.h>
#define N 12
main()
{
      char name[N];
      printf("input a string:");
      gets(name);
      printf("%s",name);
      return 0;
}
我有宏定义N=12,为哈我输入超过12个字符后依然可以输出字符串,不是不能超过12个字符吗?
最佳答案
2020-12-27 18:35:36
本帖最后由 jackz007 于 2020-12-27 19:37 编辑

        字符数组越界,侵害到了相邻变量的存储内容,运行下面的代码就可以发现是怎么回事了。
#include<stdio.h>
#define N 12
main()
{
      char name1[N] = "0123456789"   ;
      char name2[N]                  ;
      char name3[N] = "ABCDEFGHIJ"   ;
       
      printf("input a string:")      ;
      gets(name2)                    ;
      printf("name1 = %s\n" , name1) ;
      printf("name2 = %s\n" , name2) ;
      printf("name3 = %s\n" , name3) ;
}
       编译、运行实况
D:\00.Excise\C>g++ -o x x.c

D:\00.Excise\C>x
input a string:you are my good friend !
name1 = ood friend !
name2 = you are my good friend !
name3 = ABCDEFGHIJ

D:\00.Excise\C>
        可见,当字符数组 name2 被越界使用的情况下,相邻变量 name1 的内容已经完全被破坏了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-12-27 17:15:22 | 显示全部楼层
gets() 函数的功能是从输入缓冲区中读取一个字符串,你输入超过12个字符的时候,剩下的会存到输入缓冲区中
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-27 18:35:36 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2020-12-27 19:37 编辑

        字符数组越界,侵害到了相邻变量的存储内容,运行下面的代码就可以发现是怎么回事了。
#include<stdio.h>
#define N 12
main()
{
      char name1[N] = "0123456789"   ;
      char name2[N]                  ;
      char name3[N] = "ABCDEFGHIJ"   ;
       
      printf("input a string:")      ;
      gets(name2)                    ;
      printf("name1 = %s\n" , name1) ;
      printf("name2 = %s\n" , name2) ;
      printf("name3 = %s\n" , name3) ;
}
       编译、运行实况
D:\00.Excise\C>g++ -o x x.c

D:\00.Excise\C>x
input a string:you are my good friend !
name1 = ood friend !
name2 = you are my good friend !
name3 = ABCDEFGHIJ

D:\00.Excise\C>
        可见,当字符数组 name2 被越界使用的情况下,相邻变量 name1 的内容已经完全被破坏了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-27 20:01:45 | 显示全部楼层
本帖最后由 风过无痕1989 于 2020-12-27 20:03 编辑

这是由于宏定义引起的,具体原因我没有查到,我只查到了如下的实例:
 #define N 2+2
void main()
{
    int a=N * N;
    printf(“%d”,a);
}

输出 a = 8
其原因是在宏定义时,系统将 2 + 2 看作是字符串,展开时就变成了: a = N * N = 2 + 2 * 2 + 2 = 2 + 4 + 2 = 8。而并非我们所想像的 a = 16,要想 a = 16,我们得这么定义:#define N (2 + 2)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-27 21:57:01 | 显示全部楼层
产生了越界,但在printf(%s)的时候,程序是以读到‘\0’为标识符。所以你要printf它还是可以完整地输出
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-28 16:22:36 From FishC Mobile | 显示全部楼层
Aurora1 发表于 2020-12-27 21:57
产生了越界,但在printf(%s)的时候,程序是以读到‘\0’为标识符。所以你要printf它还是可以完整地输出

都越界了,编译器为啥不报错?那宏定义还有什么意义?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-28 16:23:24 From FishC Mobile | 显示全部楼层
风过无痕1989 发表于 2020-12-27 20:01
这是由于宏定义引起的,具体原因我没有查到,我只查到了如下的实例:



emmm,这个例子并不能解决我的困惑(д;)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-29 12:26:05 | 显示全部楼层
肚子饿了233 发表于 2020-12-28 16:22
都越界了,编译器为啥不报错?那宏定义还有什么意义?

忘了在哪里看到的了,好像说是宏定义尽量要定义正确,不要出现一些无意义的宏定义,就好比写作要求是写800字以内,所以你要尽量控制在800字以内,但是如果超出800字的话系统也不会直接给你报错,大概这意思。 你可以尝试用const。
宏定义是字符替换,没有数据类型的区别,同时这种替换没有类型安全检查,可能产生边际效应等错误;
const常量是常量的声明,有类型区别,需要在编译阶段进行类型检查
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-12 06:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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