肚子饿了233 发表于 2020-12-27 17:12:55

C语言!字符输入问题!

#include<stdio.h>
#define N 12
main()
{
      char name;
      printf("input a string:");
      gets(name);
      printf("%s",name);
      return 0;
}
我有宏定义N=12,为哈我输入超过12个字符后依然可以输出字符串,不是不能超过12个字符吗?

一世轻尘 发表于 2020-12-27 17:15:22

gets() 函数的功能是从输入缓冲区中读取一个字符串,你输入超过12个字符的时候,剩下的会存到输入缓冲区中

jackz007 发表于 2020-12-27 18:35:36

本帖最后由 jackz007 于 2020-12-27 19:37 编辑

      字符数组越界,侵害到了相邻变量的存储内容,运行下面的代码就可以发现是怎么回事了。
#include<stdio.h>
#define N 12
main()
{
      char name1 = "0123456789"   ;
      char name2                  ;
      char name3 = "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 的内容已经完全被破坏了。

风过无痕1989 发表于 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)

Aurora1 发表于 2020-12-27 21:57:01

产生了越界,但在printf(%s)的时候,程序是以读到‘\0’为标识符。所以你要printf它还是可以完整地输出

肚子饿了233 发表于 2020-12-28 16:22:36

Aurora1 发表于 2020-12-27 21:57
产生了越界,但在printf(%s)的时候,程序是以读到‘\0’为标识符。所以你要printf它还是可以完整地输出

都越界了,编译器为啥不报错?那宏定义还有什么意义?

肚子饿了233 发表于 2020-12-28 16:23:24

风过无痕1989 发表于 2020-12-27 20:01
这是由于宏定义引起的,具体原因我没有查到,我只查到了如下的实例:




emmm,这个例子并不能解决我的困惑(д;)

Aurora1 发表于 2020-12-29 12:26:05

肚子饿了233 发表于 2020-12-28 16:22
都越界了,编译器为啥不报错?那宏定义还有什么意义?

忘了在哪里看到的了,好像说是宏定义尽量要定义正确,不要出现一些无意义的宏定义,就好比写作要求是写800字以内,所以你要尽量控制在800字以内,但是如果超出800字的话系统也不会直接给你报错,大概这意思。 你可以尝试用const。
宏定义是字符替换,没有数据类型的区别,同时这种替换没有类型安全检查,可能产生边际效应等错误;
const常量是常量的声明,有类型区别,需要在编译阶段进行类型检查
页: [1]
查看完整版本: C语言!字符输入问题!