//------------一维数组做参数--------------
对于一维数组做实参的 参数传递问题:
void func(int *r);
void func(int[10]);
void func(int[]);
前三种是等价的,传递的都是指针,指向数组第一元素的地址。
这里参数用两个本质含义:first,传递的是实参的地址,而不是实参的拷贝。为了保持实参不被改变需要
添加const来限制参数。void func(const int *r)等。second,函数不知道你的数组的长度,他只是传递指针。编译器不对长度进行检查。
void func(int &r);
传递变量的地址,是变量的别名。别名引用
有一种方法是
void func(int (&arr)[10]);这种形参,在编译时,编译器会对参数传递的长度进行检查。
//-------------对于二维数组做实参的 参数传递问题;------------------------
当多维数组多参数时,void func(int (*)[])其中(*)和[]是一个作用,本质都是*
以下形式等价:func(int**) func(int (*a)[n]) func(int a[][n]) func(int (&arr)[m][n]) 但是从程序的实验看,
func(int**a) 子函数用func(a)(其中a 为a[3][3]的数组名)调用时,出现 实参与形参类型不匹配的错误而其他的子函数调用就没有问题。不知何故。
//-------------------------------------------------------------------------------------------------------------------
//-------------c++ primer 中关于& * and [] 运算符 优先级的问题 priority
int *mat[10] 与 int (*mat)[10] 的区别:一个是前边是指针的数组;后者是数组的指针。
理解的关键在于,* 与 []两个运算符的运算优先级。后者优先。
为防止越界,C风格是用一个NULL字符来标记字符串的结束,而标准模板库用用最后一个元素
的下一个指针来做纺织越界。在C++ 标准化之前,通过添加一个形参,记录数组的长度来防止
数组的越界。//-----------------------------------------------------------------------------------------------------------------------
当数组作为形参时,编译器只会检查实参是不是指针,以及指针类型是否与形参匹配。
而不会检查参数的长度。因为你即使把形参写成int a[]的数组形式,他并不会当成数
组对待,而是退化为指针。
当用数组作为实参,传递给子函数形参时,不需要改变数组元素值的话,尽量写上const
来约束参数,以防不小心透过形参修改实参中的数据.
数组也可以被“引用”来作为形参,如:void func(int (&arr)[10]). 此时传递的是数组,
的引用,是别名,而不再退化为指针。不过要注意,在你用数组引用时,编译器会检查数
组的长度,必须长度为10,否则编译出错。可以写程序验证一下。并进行解释,理解会更
透彻。