是否可以声明一个大小为 1 的数组并能够在其中存储 5 个元素然后检索它们?
我尝试了一个这样的代码,我声明了一个数组arr[1]
,然后在其中存储了 5 个元素。实际上可以存储 5 个元素!它曾是怎样的?
是否可以声明一个大小为 1 的数组并能够在其中存储 5 个元素然后检索它们?
我尝试了一个这样的代码,我声明了一个数组arr[1]
,然后在其中存储了 5 个元素。实际上可以存储 5 个元素!它曾是怎样的?
如果这是 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
)。