是否可以声明一个大小为1的数组,并且能够在其中存储5个元素然后检索它们?
我尝试了一个这样的代码,我声明了一个数组arr[1]
,然后将5个元素存储到其中。实际上可以存储5个元素!怎么回事?
答案 0 :(得分:2)
如果这是C(或C ++),你可以很容易地存储比数组大小更多的元素:
#include <stdio.h>
int main (void) {
int x = 0;
int a[1]; // so that a[0] is the only valid element
a[1] = 7; // write beyond end of array
printf ("x=%d, &a[0]=%p, &a[1]=%p, &x=%p\n", x, &(a[0]), &(a[1]), &x);
return 1;
}
然而,这样做会导致未定义的行为,可能会覆盖一些其他信息,并不是一个好主意。
在我的系统上,上面的代码打印出来:
x=7, &a[0]=0xbf9bb638, &a[1]=0xbf9bb63c, &x=0xbf9bb63c
尽管我将x
设置为零并且从未明确更改过它。那是因为超出数组末尾的写入已经影响了它(正如您从a[1]
和x
的两个相同地址中看到的那样。)