var和_ptr之间的相互赋值-Read.ppt

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
_var和_ptr之间的相互赋值 B为基类,D为派生类 B_ptr=B_ptr;//浅赋值 B_ptr=D_ptr//浅赋值 D_ptr=B_ptr//非法,编译时出错 B_ptr=B_var;//浅赋值,B_var保留所有权 B_ptr=D_var//浅赋值,D_var保留所有权 D_ptr=B_var//非法,编译时出错 B_var=B_ptr;//浅赋值, B_var得到所有权 B_var=D_ptr//浅赋值, D_var得到所有权 D_var=B_ptr//非法,编译时出错 B_var=B_var;//深赋值 B_var=D_var//非法,编译时出错,要使用 B_var=D::_duplicate(D_var);才可以 D_var=B_var//非法,编译时出错 _var引用与拓展 _var引用负责释放引用,但是它们不允许通过其它的_var类型对它们进行隐含的拓展赋值或初始化。 CORBA::Object_var obj; B_var x1; D_var x2; obj=x1;//编译错误 obj=x2; //编译错误 X2=x1; //编译错误 B_var x1; D_var x2(x1);//编译错误 调用显式的_duplicate可以 B_var x1; D_var x2; X2=D:: _duplicate(x1); X2=B:: _duplicate(x1); x2=D:: _duplicate(x1); D:: _duplicate()需要用到D_ptr类型的参数。编译器可以找到一个匹配,因为D_var中有一个可以转换成D_ptr的转换运算符,它与D_ptr相兼容(使用C++的标准转换)。 D:: _duplicate()拷贝传递来的引用,并且将拷贝作为D_ptr返回,x2拥有对该拷贝的所有权。 x2=B:: _duplicate(x1); B:: _duplicate()需要用到B_ptr类型的参数。编译器可以找到一个匹配,因为实际参数中有一个用户定义的从B_var到B_ptr的转换函数,由duplicate 返回的拷贝是B_ptr类型,通过C++标准转换规则可以将它拓展为D_ptr类型;x2拥有对该指针的所有权。 为什么在_var类型之间的隐式拓展是禁止的,而需要显式调用_duplicat。 原因是:这样的拓展赋值可能不能执行,拓展赋值需要基类了解所有派生类的信息,否则会导致类型系统变得不严格,甚至使紧缩赋值都变为合法,这将会破坏C++的类型安全性。 对象引用_var类 B_var();空引用 B_var(B_ptr );引用计数不增加 B_var(const B_var );引用计数增加 ~B_var() B_var operator=(B_ptr ) B_var operator=(const B_var ) operator B_ptr ();//D_var转成B_ptr B_ptr in() const; B_ptr inout(); B_ptr out(); B_ptr _retn(); * *

文档评论(0)

wendang_1 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档