在MFC当中我们比较容易看到用#define定义的宏,但是红定义却比较容易出错。
以下是修改《effective C++》中的
#define CALL_WITH_MAX(a,b) (a)>(b)?(a):(b);
当我们计算
int a=5;
int b=0;
int c=CALL_WITH_MAX(++a,b);
时候 我们会对a加了两次这是因为#define 是在预编译时候就进行替换。所以在编译的时候,其实处理的是
int c=(++a)>(b)?(++a):(b);
而当a>b的时候,a加了两次,小于等于时候加了一次。
#include<iostream>
#define CALL_WITH_MAX(a,b) (a)>(b)?(a):(b);
using namespace std;
int main()
{
int a=5;
int b=0;
int c=0;
c=CALL_WITH_MAX(++a,b);
cout<<c<<endl;
return 0;
}
所以我们尽量不用而是采用c++中的template
#include<iostream>
using namespace std;
template<typename T>
inline void callwithmax(const T&a,const T&b)
{
cout<< (a>b?a:b);
}
int main()
{
int a=5;
int b=0;
int c=0;
callwithmax(++a,b);
return 0;
}
本文通过一个具体的示例对比了C++中宏定义与模板在处理相同问题时的区别,指出了宏定义可能导致的意外副作用,并推荐使用模板来避免此类问题。

866

被折叠的 条评论
为什么被折叠?



