宏的缺点:
1因定义常量宏未记录在记号表,在使用此常量时编译报错得到为宏值相关信息,如果此宏定义在非本人定义的头文件内,追踪排查困难
2无法用#define创建一个类专属常量如果是类的专属常量(限定作用域在类内),如果需要只有一份实体,加static修饰
初始化方法如下:
class A{
public:
//static const int num = 5;//如果不OK可以用上面的
//const int num = 5; //no
#define MAX(a,b) f((a)>(b)?(a):(b))
cout << MAX(++a, b) << endl; //7 a累加二次
cout << MAX(++a, b+10) <<a<< endl//10 a累加一次
利用内联函数代替
优点:参数不会核算多次 并遵守作用域和访问规则
template<typename T>
inline void MAX(const T&a,const T&b){
f(a>b?a:b);
}
1因定义常量宏未记录在记号表,在使用此常量时编译报错得到为宏值相关信息,如果此宏定义在非本人定义的头文件内,追踪排查困难
2无法用#define创建一个类专属常量如果是类的专属常量(限定作用域在类内),如果需要只有一份实体,加static修饰
初始化方法如下:
class A{
public:
static const int a =10;
};
const int A::a ;//----------------
classA{
public:
static const int a;
};
const int A::a = 10;
//--------
class A{
//enum{num=5};//ok//static const int num = 5;//如果不OK可以用上面的
//const int num = 5; //no
int scores[num];
}
3 无语法检查#define MAX(a,b) f((a)>(b)?(a):(b))
cout << MAX(++a, b) << endl; //7 a累加二次
cout << MAX(++a, b+10) <<a<< endl//10 a累加一次
利用内联函数代替
优点:参数不会核算多次 并遵守作用域和访问规则
template<typename T>
inline void MAX(const T&a,const T&b){
f(a>b?a:b);
}