【SQL Server DBA】日常维护语句

如果我们需要编写一个处理二维数组的函数,那么这个函数原型应该如何声明呢?


首先,我们应该牢记:数组名被视为其地址,因此,相应的形参是一个指针。例如,假设有如下的代码:


int data[3][4] = { {1, 2, 3, 4}, {5, 5, 7, 8}, {9, 10, 11, 12} }
int total = sum(data, 3);
那么sun函数的原型应该如何声明呢?为什么将行数3作为参数,而不将列数4作为参数呢?


我们可以这样理解:data 是一个数组名,该数组有3个元素。而这3个元素本身都是又4个 int 组成的数组。因此 data 的类型是 指向由4个int组成的数组的指针。

因此正确的 sum 原型如下:

int sum( int (*arr) [4], int size);
//其中的括号是必不可少的,因为下面的声明将声明一个由四个指向int的指针组成的数组,而不是一个指向由4个int组成的数组的指针。

int *arr[4];   //声明了一个指针数组,这个数组包含4个int指针变量
int (*arr)[4] //声明了一个指针变量,这个指针指向由4个int组成的数组

还有另外一种声明格式,含义与上述正确原型完全相同,但是可读性更强:

int sum(int arr[][4], int size);

上述2个原型都指出,arr 是指针而不是数组。还需要注意的是:int arr [ ] [4] 的含义就是: arr 是指向由4个 int 构成的数组的指针。因此,指针类型指定了列数,也就是说:函数形参已经确定了实参数组的列数,这就是为什么没有将列数作为独立的函数参数进行传递的原因



【SQL Server DBA】日常维护语句,布布扣,bubuko.com

【SQL Server DBA】日常维护语句

上一篇:批量解密SQLSERVER数据库中的各种对象的工具dbForge SQL Decryptor


下一篇:MongoDB 只允许本地访问