1、行指针
int a[5][10],(*q)[10]=a;
上面定义定义了行指针q,并定义时直接赋值,等价于
int a[5][10],(*q)[10];
q=a;
行指针是为了配合二维数组才使用的,没有二维数组,用不到行指针。
如果所有操作都在主函数里,没有必要使用行指针,因为用数组名就可以表达每个元素:a[i][j]
如下面代码:
#include "stdio.h"
#define M 5
#define N 10
main()
{
int a[M][10]={
{1,2,3},{4,5,6},{7,8,9},{6,6,6},{8,8,8}};
int i,j;
//输出原始数据
for(i=0;i<M;i++)
{
for(j=0;j<N;j++)
printf("%5d",a[i][j]);
printf("\n");
}
//数组每个元素的值+1
for(i=0;i<M;i++)
for(j=0;j<N;j++)
a[i][j]+=1;
//输出计算后的数据
printf("输出计算后的二维数组:\n");
for(i=0;i<M;i++)
{
for(j=0;j<N;j++)
printf("%5d",a[i][j]);
printf("\n");
}
}
这里没用到也不需要行指针就可以完成任何操作。
但是,我们知道,多人合作开发,功能都是要放到不同的函数里,我们将功能:每个元素的值+1,放到一个fun函数中实现,看看怎么解决。
……
……
没办法解决。
为啥?
因为fun函数得不到主函数二维数组a的任何信息。
只有行指针才可以做到。
看下面代码:
#include "stdio.h"
#define M 5
#define N 10
void fun(int (*q)[M])//q是行指针变量,也可以写成int q[][M],q得到实参的值a,也就是行指针q保存了行地址a
{
int i,j;
//数组每个元素的值+1
for(i=0;i<M;i&