
展开全部
a[i] 指首地址为a,第a+i的位置存储的数据 所以等效于*(a+i)
首先要明确 * 的对象是指针
所以 此时数组a中存储的应为指针
(就是数组中存储的数据 是指针)
而(*a)[i]指的是数组(*a)的第(*a)+i位置上的数据,所以(*a)必须是指针
这样就有了 当我们定义int **top,data,a[100],*p,**2p,***3p,.......******..***np;
则可以有一下赋值
np=&(n-1)p;
.
.
.
2p=&p;
p=a;
p=&data
//不可以与这个顺序有区别,譬如 3p=&p;相同级别可以直接赋值 比如2p=top;
这样的意义在于 每次 *运算都是对指针中的数据进行操作,当遇到要对指针所指向的最后一个数据也就是非指针数据操作的时候可以通过多次*运算寻址找到最后一个指针所指的数据,也可以避免由于指针互相指示而导致的死循环;
首先要明确 * 的对象是指针
所以 此时数组a中存储的应为指针
(就是数组中存储的数据 是指针)
而(*a)[i]指的是数组(*a)的第(*a)+i位置上的数据,所以(*a)必须是指针
这样就有了 当我们定义int **top,data,a[100],*p,**2p,***3p,.......******..***np;
则可以有一下赋值
np=&(n-1)p;
.
.
.
2p=&p;
p=a;
p=&data
//不可以与这个顺序有区别,譬如 3p=&p;相同级别可以直接赋值 比如2p=top;
这样的意义在于 每次 *运算都是对指针中的数据进行操作,当遇到要对指针所指向的最后一个数据也就是非指针数据操作的时候可以通过多次*运算寻址找到最后一个指针所指的数据,也可以避免由于指针互相指示而导致的死循环;
展开全部
不一样,看运算符的结合优先级·~
*a[1] //a首先与[]结合,所以a是一个数组。数组元素的类型为指针
(*a)[1] //a先于*结合,所以a是一个指针。指针可以指向一个只有一个元素的数组
*a[1] //a首先与[]结合,所以a是一个数组。数组元素的类型为指针
(*a)[1] //a先于*结合,所以a是一个指针。指针可以指向一个只有一个元素的数组
追问
第一个可以等价于a[][1]吗
追答
a[][1]一般这样定义二维数组的话,行数由初始化决定。
如int a[][3]={{0}{}}; //则表示定义2行3列的二维数组
第一个*a[1]则表示一维数组,a[][1]是二维数组。不等价
一般二维数组可以看做一维数组,数组元素为一维数组。
而这里
*a[1] 一维数组元素为指针~~指针指向何方不定,即未分配内存(因为是指针)
而a[][1]
若看做一维数组的话,则元素为一维数组,已分配内存(因为是数组)
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不一样,前者是元素a[1]的地址,等价于a+1,后者等价于a[1]
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
a是怎么定义的?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询