数组和栈
//建议先去看栈的机理再来看这个
经测试,数组定义的时候b的地址在a的前面,正好是连续的空间。
然后接收时多出来的第九个字符,’\0’,被写到了a[0]的位置里。
因为a[0]已经是’\0’,那么打印的时候%s会识别a[0]就是字符串结束的地方,不再输出后面的字符。
b数组里面仍然是原样,所以被正常输出了。
GCC-32位
char a[8];
char b[8];
scanf("%s",a);
scanf("%s",b);
输入12345678 12345678
输出如下: 地址+ASCII码
&a[0]:0028FF14 0
&a[1]:0028FF15 50
&a[2]:0028FF16 51
&a[3]:0028FF17 52
&a[4]:0028FF18 53
&a[5]:0028FF19 54
&a[6]:0028FF1A 55
&a[7]:0028FF1B 56
&b[0]:0028FF0C 49
&b[1]:0028FF0D 50
&b[2]:0028FF0E 51
&b[3]:0028FF0F 52
&b[4]:0028FF10 53
&b[5]:0028FF11 54
&b[6]:0028FF12 55
&b[7]:0028FF13 56
##12345678##
同理如输入
123456789 123456789
得到
9##123456789##
因为前一个字符数组中已经有两位被后一个字符串多出来的地方占用。