高质量C++编程指南-笔记.docVIP

  1. 1、本文档共2页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
1 如果函数返回值是一个对象,要考虑return语句的效率。例如 return String(s1 + s2); 这是临时对象的语法,表示“创建一个临时对象并返回它”。不要以为它与“先创建一个局部对象temp并返回它的结果”是等价的,如 String temp(s1 + s2); return temp; 实质不然,上述代码将发生三件事情。首先,temp对象被创建,同时完成初始化;然后拷贝构造函数把temp拷贝到保存返回值的外部存储单元;最后,temp在函数结束时被销毁(调用析构函数)。然而“创建一个临时对象并返回它”的过程是不同的,编译器直接把临时对象创建并初始化在外部存储单元中,省去了拷贝和析构的花费,提高了效率。 类似的,我们不要将 return int(x + y); // 创建一个临时变量并返回它 写成 int temp = x + y; return temp; 由于内部数据类型如int,float,double得变量不存在构造函数和析构函数,虽然该“临时变量的语法”不会提高多少效率,但是程序更加简洁易读。 C99? 6.4.5 ? String ? literals? 6. ? It ? is ? unspecified ? whether ? these ? arrays(指常量字符串)are ? distinct ? provided ? their ? elements ? have ? the ? appropriate ? values. ? If ? the ? program ? attempts ? to ? modify ? such ? an ? array, ? the ? behavior ? is ? undefined.? C++标准(first ? edition)? 2.13.4? 2. ? whether ? all ? string ? literals ? are ? distinct ? is ? implementation-defined. ? The ? effect ? of ? attemping ? to ? modify ? a ? string ? literal ? is ? undefined.? char* p = hello\n; p[0] = X; [undefined] 未定义行为是在某些不正确的情况下,标准并未规定应该怎样做,实现可以采取任何行动,也可以什么都不做。 如当有符号整数溢出时该采取什么行动。 [unspecified] 未确定行为是在某些正确的情况下,标准并未规定应该怎样做。 如函数参数的求值顺序。 [implementtation-defined] 实现定义的行为是由编译器设计者决定采取何种行动,并写入实用手册。 如当一个整型数向右移位时,要不要扩展符号位。 new / delete 是 operator 调用new / delete 可是调用类的constructer and destructor. Overloading and Return Type Return types are not considered in overload resolution. This reason is to keep resolution for an individual operator or function call context-independent. Consider: float sqrt(float); double sqrt(double); void f(double da, float fla) { float fl = sqrt(da); // call sqrt(double) double d = sqrt(da); // call sqrt(double); fl = sqrt(fla); // call sqrt(float); d = sqrt(fla); // call sqrt(float); } If the return type were taken into account, it would no longer be possible to look at a call of sqrt() in isolation and determine which function was called. 基类与派生类的析构函数应该为虚函数(virtual)

文档评论(0)

80092355km + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档