不要以为函数尚未调用时,数组就没规划空间。
若用参数为数组指定元素个数,等函数被调用时,形参就有值了,此时创建数组m和n都已确定,于是就写成
void user(int m, int n)
{
char A[m][n];
}
这种写法是错误的,数组(动态分配的除外)的大小是在编译的时候就“规划了”空间需求。尽管尚未真正分配空间。而形参变量在函数未调用时其值未定,编译器无法得到需求信息,无法完成数组的编译。
其内幕是:
在内存得到堆区,存放第一个元素的位置之前,开辟了一个结构体变量,其成员之一是unsigned int型的成员,用来存放元素个数。用_msize(p)会得到p所指向的堆内存数组所占的总字节数。
但在静态区和栈区的数组不是这样,而是将元素个数信息保存在“变量名表”中。
当用指针指向该数组时,指针无法保存这个信息,虽然可以王文到每个数组元素,但只要知道地址,并不知道是再操作数组。这正是数组与指针的区别。
当数组作为函数的参数进行传递时,该数组自动蜕化为指针。