首页 | 互联网 | IT动态 | 网络设备 | 服务器 | IDC | 安全 | Cisco | Windows | Linux | Java | .Net | Oracle | CIW | 华为 | 专题
IT技术 | 网页设计 | 平面设计 | 电子书下载 | 教学视频 | 方案 | 数字网校 | 直播室 | 虚拟考场 | 面授培训 | 搜索 | 博客 | 沙龙 | 论坛
中国IT实验室Dotnet频道
中国IT教育
首页 ASP.NET  C#  XML/WebService ADO.NET VC.NET VB.NET .NET 资讯动态 专题 RSS订阅 讨论 下载
您现在的位置: 中国IT实验室 >> Dotnet >> VC.NET >> 文章正文

C++指针使用方法解惑

文章来源中国IT实验室收集整理 作者佚名 更新时间2007-5-20 保存本文保存本文 推荐给好友推荐给好友 收藏本页收藏本页

    在下列函数声明中,为什么要同时使用*和&符号?以及什么场合使用这种声明方式? 

   void func1( MYCLASS *&pBuildingElement );   
  论坛中经常有人问到这样的问题。本文试图通过一些实际的指针使用经验来解释这个问题。
 仔细看一下这种声明方式,确实有点让人迷惑。在某种意义上,"*"和"&"是意思相对的两个东西,把它们放在一起有什么意义呢?。为了理解指针的这种做法,我们先复习一下C/C++编程中无所不在的指针概念。我们都知道MYCLASS*的意思:指向某个对象的指针,此对象的类型为MYCLASS。    void func1(MYCLASS *pMyClass); 
   
// 例如:    MYCLASS* p = new MYCLASS;
   func1(p);   
  上面这段代码的这种处理方法想必谁都用过,创建一个MYCLASS对象,然后将它传入func1函数。现在假设此函数要修改pMyClass:    void func1(MYCLASS *pMyClass)
   {
     DoSomething(pMyClass);
     pMyClass = // 其它对象的指针
   }
   
  第二条语句在函数过程中只修改了pMyClass的值。并没有修改调用者的变量p的值。如果p指向某个位于地址0x008a00的对象,当func1返回时,它仍然指向这个特定的对象。(除非func1有bug将堆弄乱了,完全有这种可能。)
现在假设你想要在func1中修改p的值。这是你的权利。调用者传入一个指针,然后函数给这个指针赋值。以往一般都是传双指针,即指针的指针,例如,CMyClass**。    MYCLASS* p = NULL;
   func1(&p);
   
   void func1(MYCLASS** pMyClass);
   {
     *pMyClass = new MYCLASS;
     ……
   }
   
调用func1之后,p指向新的对象。在COM编程中,你到处都会碰到这样的用法--例如在查询对象接口的QueryInterface函数中:    interface ISomeInterface { 
     HRESULT QueryInterface(IID &iid, void** ppvObj); 
     …… 
   }; 
   LPSOMEINTERFACE p=NULL; 
   pOb->QueryInterface(IID_SOMEINTERFACE, &p);  

[1] [2] 下一页  

【责编:Youping】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·Java入门 Tomcat的配置技巧精华专题
 ·Oracle RMAN物理备份技术详解
 ·JAVA开发利器——JBuilder知多少
 ·Hello,web2.0技术进阶专题
 ·从入门到精通 java初学者实践系列教程
 ·JAVA 与 .NET两强对垒 到底该选什么?
 ·新手必读 认识JAVA涉及的名词
 ·WEB应用集群技术专题
 ·携手未来——Ajax技术专题
 ·Oracle入门基础专题
 今日更新
 社区讨论
 博客论点
 频道精选
 Dotnet频道相关导航