0
是否可以声明一个大小为1的数组,并能够在其中存储5个元素,然后检索它们?数组大小小于no。存储在其中的元素
我尝试了一个这样的代码,我宣布了一个数组arr[1]
,然后在其中存储了5个元素。实际上可以存储5个元素!它怎么样?
是否可以声明一个大小为1的数组,并能够在其中存储5个元素,然后检索它们?数组大小小于no。存储在其中的元素
我尝试了一个这样的代码,我宣布了一个数组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
的两个相同地址中看到的那样)。
你的编程语言是什么? – 2012-04-13 08:56:06
取决于编程语言。所以无法给出明确的答案。 – 2012-04-13 09:11:18
我想他是在谈论C.当然。 – Surya 2012-04-15 09:38:01