标签:
内容从侯捷译版的《Effective C++》(第三版)摘录
条款一
C++作为一个多种范式融合的语言,可以看成是语言的联邦,它包含了一下四种主要的次语言:
高效编程守则视状况而变化,取决于你使用C++的哪一部分。
条款二 尽量以 const, enum, inline替换#define
原因在于,#define RATIO 1.6, 中被替换的记号名称RATIO可能从来都没有出现在symbol table中,这样给debug带来很多困难。
使用const代替#define作为常量时,需要注意对于字符串的使用,即“从右往左读规则”:
const char* const authorName = "Meyers"
常量的指针变量authorName指向常量的char(s)。
另外,#define不具备封装性,比如作为class的专属常量:
class GamePlayer{ private: static const int NumTurns = 5; int scores[NumTurns]; ... };
然而以上的申明式不会通过某些编译器,所以需要加入一个定义式:
class GamePlayer{ private: static const int NumTurns; int scores[NumTurns]; ... }; const int GamePlayer::NumTurns = 5;
还有一种使用"enum hack"补偿做法,利用了emun的特点来代替常量,来限制不可取地址的常量成员变量:
class GamePlayer{ private: enum{NumTurns = 5}; int scores[NumTurns]; ... };
使用#define定义函数的缺点太多,例如:
#define CALL_WITH_MAX(a,b) f( (a) > (b) ? (a) : (b) ) int a = 5, b = 0; CALL_WITH_MAX(++a,b); // a被累加二次 CALL_WITH_MAX(++a,b + 10); // a被累加一次 而使用template,代替#define就不需要担心这样的不同: template<typename T> inline void callWithMax(const T& a, const T& b) { f(a > b ? a : b); }
Effective C++(第三版)笔记 ---- 第一部分让自己习惯C++
标签:
原文地址:http://www.cnblogs.com/JimmyTY/p/5561068.html