展开全部
行指针是一种形象的说法,比如现在有x行x列的表格。p指针指向第一行,行指针特点就是比如p+1,那么p就指向下一行的首地址。普通指针+1 就指向下一个,注意是下一个地址。行指针是指向下一行。
数组指针就是一个数组的地址,行指针出现在二维数组里就是是二级指针那里附近,例如 int a[10][5];
那么二维数组可以可分为行和列,那么要找到每一个数组就要通过哪行和哪列查找,a[10][10]中第一个小标表示行,第二个下标表示列,那么 a[1],a[2]表示对应行的指针,记得在二维数组中约定a[1],a[2]表示的是指针,在一维数组中a[1],a[2]表示的是元素,我知道你云里雾里的这里比较难记住既可以了,不要问为什么,记得这是语法规定的就可以了
数组指针就是一个数组的地址,行指针出现在二维数组里就是是二级指针那里附近,例如 int a[10][5];
那么二维数组可以可分为行和列,那么要找到每一个数组就要通过哪行和哪列查找,a[10][10]中第一个小标表示行,第二个下标表示列,那么 a[1],a[2]表示对应行的指针,记得在二维数组中约定a[1],a[2]表示的是指针,在一维数组中a[1],a[2]表示的是元素,我知道你云里雾里的这里比较难记住既可以了,不要问为什么,记得这是语法规定的就可以了
展开全部
你说的行指针应该是指向数组的指针吧?
数组指针本质上是一个指针,而指针数组是一个数组,关于指针和数组的区别两者都有。
声明的不同:
数组指针:int (*a)[N];
指针数组:int *a[N];
指针的运算结果不同:假设N=64,sizeof(int)=4,&a=0x10000
数组指针:a+1 = 0x10100 = (int)&a + N*sizeof(int)
指针数组:a+1 = 0x10004 = (int)&a + sizeof(int*)
使用上的不同:
数组指针:一般用在传递二维数组时的参数上
int find_max(int a[][100]) // 只有在形参里这样写才是数组的指针,这里是宽度为100的数组的指针
指针数组,一般用于保存很多指针,比如字符串数组
char *strings[100] = {"abc", "bcd", "efg"};
数组指针本质上是一个指针,而指针数组是一个数组,关于指针和数组的区别两者都有。
声明的不同:
数组指针:int (*a)[N];
指针数组:int *a[N];
指针的运算结果不同:假设N=64,sizeof(int)=4,&a=0x10000
数组指针:a+1 = 0x10100 = (int)&a + N*sizeof(int)
指针数组:a+1 = 0x10004 = (int)&a + sizeof(int*)
使用上的不同:
数组指针:一般用在传递二维数组时的参数上
int find_max(int a[][100]) // 只有在形参里这样写才是数组的指针,这里是宽度为100的数组的指针
指针数组,一般用于保存很多指针,比如字符串数组
char *strings[100] = {"abc", "bcd", "efg"};
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询