请看一下c++程序 (1)(2)(3) 编译都没有错误,为什么只有(3)能运行,还有既然a是二级指针,(6)为啥错

#include"iostream.h"voidmain(){intx=0,*p,**q,a[2][2]={1,2,3,4};p=&x;cout<<p<<endl;(1)... #include "iostream.h"
void main()
{
int x=0,*p,**q,a[2][2]={1,2,3,4};
p=&x;
cout<<p<<endl;
(1) **q=*p;
(2) *q=p;
(3) q=&p;
cout<<q<<" "<<*q<<" "<<**q<<endl;
(4) p=a;//错误
(5) p=a[0];//正确
(6) q=a;
}
展开
 我来答
阔海的账户
2012-04-13 · TA获得超过214个赞
知道小有建树答主
回答量:161
采纳率:0%
帮助的人:240万
展开全部
首先 q作为指针的指针,没有初始化,其指向的地址就是一个随机的地址,这个地址一般是不能访问的,所以*q=p会出现访问异常。就算是能访问,其内容所指向的地址也是一个不确定的值,一般也是不能访问的,所以对这个地址的内容的赋值 **q=*p 几乎合一肯定会出现异常。

其次,指针的指针和二维数组是两个概念。可以把指针的指针理解为一个指针数组的首地址。例如定义 int * p[20]; int **q; q=p就是合法的,相当于q = &p[0]。
而对于二维数组,如果要定义一个指针能够指向一个向量,应该定义和这个二维数组相匹配的指针,有固定的第一维。比如:int a[2][2]; int (*qq)[2]; 这里qq就是指向一个二维数组的指针,这个二维数组的第一维是固定有2个元素。这样可以赋值:qq=a; 赋值后,qq[0]就是第一个向量,qq[2]就是第二个向量,qq[0][1]就等于aa[0][1]。

这也是我的理解。一般较少这样用。而且调试起来还有些难度。除非以指针的形式可以化简一些表达或者调用关系。
huanghaohongso
2012-04-13 · TA获得超过2万个赞
知道小有建树答主
回答量:968
采纳率:50%
帮助的人:351万
展开全部
1错在**q没有指向任何变量或合法内存单元,自然就不可以赋值;这跟char *p;pringt("%c",*p);错误相似,都是无法确定合法的存储单元,没有初始化。
2与1的原因是一样的,p变量有对应的内存单元,*p与**p都没有合法对应的内存单元,你还没给他们指明,必定导致非法访问错误。
3这就明了了,q作为变量是有确定的对应内存单元的。
4,p与a类型并不匹配,一个是对应着一个整数的指针---p;a却是对应着两个整数的行指针。
5由4的行指针说法可知正确,因为行指针对应着一个一维数组(也就一行数),该数组中的元素都是指针,下标访问改行数组中的元素。a【0】就得到第一个整数的指针。
6 也是类型不匹配,虽然都是二级指针,也可以说都是行指针,但q只是只有一个元素的行的指针,而a是装有两个元素的行指针。
阿门。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
djh543
2012-04-13 · TA获得超过156个赞
知道小有建树答主
回答量:74
采纳率:0%
帮助的人:86.8万
展开全部
(1)是因为q还没有指向地址,所以会溢出。
(2)跟上面差不多,二次地址还没有,还不能将它指向一次地址。
上面解决的办法是倒过来
q=&p;
*q=p;
**q=*p;
依顺序,一级一级赋值。
(4)从意义上来说a[0]才是一次指针的地址,也可以p=(int*)a
(6) 发现a与a[0]的值相同,证明a不是二次指针的地址。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式