c语言中字符串输入的长度会超过我定义的字符数组,为什么输入的内容还是能输出?
会有什么影响吗?
c语言中的数组变量的名字有两个含义,一个是作为标记数组的唯一性,比如你不能在同一段代码内再次以同一个名字来命名另外一个变量;另一个就是它存储的是数组内存位置的首地址;
所以当你将一段大于数组长度的数据往该数组中写入的时候,实际上是以首地址开始依次写入,由于c语言没有显式的越界检查,除非你写入到一块不可写的内存中,c语言才会报错;
而在访问的这个数组内容的时候,比如你以%s,去打印一个char str[10] = "12345678901234"的时候,%s的打印规则是从首地址开始,直到遇见'\0'停止,所以能够打印出"12345678901234",因为以char str[10] = "12345678901234"这种方式为一个数组进行初始化的时候末尾是自动加'\0'的。
所以在对数组进行初始化或者赋值的时候,最好是使用带有长度参数的拷贝函数或者自己去做赋值长度的限定,不然容易在写的时候出问题。并且,有可能你越界的数据结尾的'\0'有可能被其他代码或者程序擦除,这个时候读出来的数据就变成非可控的了。
代码我没看到,不过你可能是下面这种情况,
你因该是使用字符数组变量来用scanf扫描标准输入,然后打印,这样是不行的。你应该用字符指针而不是字符数组。
如果你定义字符数组
char a[5] = “12345”;
那么实际a[5]所存储的是 '\0'。
a指向数组第一个元素,即a[0],也就是&a与&a[0]是同一地址。
你在printf函数打印a,实际上printf函数是从a地址开始一个一个往后打印,直到碰到'\0'为止。
printf("s%",a); //会输出12345,碰到\0才会停止
如果你是用scanf("%s",a)来输入,你输入123456,a相当于指针,a[5]存储'6',a[6]才是'\0',
这时printf("s%",a); 碰到\0才会停止,所以输出123456
输出字符串是以 \0 结束,不是以内存大小,因为他也不知道大小。你这样子并不是100%都能成功,稍微复杂点就会崩溃。你这是内存溢出了。错误的编程。
如果是char a[3 ];
gets(a);
可能是可以超过的,但是超过的字符是不定的,它可能被其它数据顶替,不建议这样做,这样一般只能输2个字符,最后一个为/0