当前位置:主页   - 电脑 - 程序设计 - C/C++
《Effective C++》读书笔记02:用const,enum,inline减少#define出场机会
来源:网络   作者:   更新时间:2011-01-18
收藏此页】    【字号    】    【打印】    【关闭

  以前学习c语言时,老师教导我们,对于数字最好用宏(#define)来定义它。以至于一直习惯于#define Age 12这样的写法。

  在c语言的环境中,这确实是增加程序可读性的有效做法,可是在c++中,可以有更优美的实现方式。

  1.当你写下

#define NUMBER 11.12

  如果接下来使用NUBMER时出现了编译错误,那么由于在预处理过程中NUMBER已经被替换为11.12了,编译器指出错误发生在11.12上,如果使用者不是你,肯定会对11.12感到莫名其妙,要花不少时间追踪它。

  替换方法有:

const double Number = 11.12;

  这样一来,错误定位肯定没有问题了,而且如果多次使用这个常量,宏替换会产生多份11.12,而后者保证只有一个副本。

  2.我以前写过这样的宏替换代码:

#define MAX(a, b) ((a) > (b) ? (a):(b)) //得到两个数中的最大值

  在每个变量外都加了括号以后,使用起来确实没碰到过什么问题。可是作者这样使用这个函数:

int a = 5, b = 0;
MAX(++a, b); //a会被递增两次
MAX(++a, b+10); //由于b+10>a,a只被递增一次!!

  会出现很大的问题!

  在c++中,可以使用inline函数来解决:

template<typename T>
inline T MAX(const T& a, const T&b)
{
  return a > b ? a : b;
}

  使用reference-to-const可以确保不对对象进行修改;而inline函数本身可以在编译时进行优化,提高编译速度。

  Note:

  1.对于一般常量,最好用const和enum替换#define;

  2.对于类似函数的宏,最好改用inline函数替换#define。

  系列文章:

  《Effective C++》读书笔记01:视c++为一个语言联邦

  《Effective C++》读书笔记02:用const,enum,inline减少#define出场机会

  《Effective C++》读书笔记03:多才多艺的const

  《Effective C++》读书笔记04:确保对象在使用之前被初始化

  《Effective C++》读书笔记05:c++默默为您编写的函数

  《Effective C++》读书笔记06:如果不要编译器自动生成的函数,就明确拒绝

  《Effective C++》读书笔记07:为多态基类声明virtual析构函数

  《Effective C++》读书笔记08:别让异常逃离析构函数

  《Effective C++》读书笔记09:绝不在构造和析构过程中调用virtual函数

  《Effective C++》读书笔记10:令operator=返回一个引用指向*this

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明