Rumah > Soal Jawab > teks badan
我以前写过这样的宏替换代码:
#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只被递增一次!!
问:问题产生原因?解决方案?
黄舟2017-04-17 13:06:46
首先,你要明白,define就是进行简单的替换,这是第一点,基于此,我们就将你提供的两个表达式使用宏来进行替换,然后你就会明白了。
((a) > (b) ? (a) : (b)) => ((++a) > (b) ? (++a) : (b))
((a) > (b) ? (a) : (b)) => ((++a) > (b+10) ? (++a) : (b+10))
你再把值填进去计算,你就应该明白了。
先判断a是否大于b,此时会进行一次++运算操作;当a大于b时,会返回++a表达式,会再次进行一次++操作;我说的比较绕,我想你应该懂我的意思。
解决方案就是,不要在宏中使用会改变自己值的运算符,比如++,--等,这样会让你很晕的。
天蓬老师2017-04-17 13:06:46
http://www.cnblogs.com/safeking/archive/2008/03/21/1116302.html
去掉副作用的最小宏定义方式(linux kernel定义)
159: #define min_t(type,x,y) \
160: ({ type __x = (x); type __y = (y); __x < __y ? __x: __y; })
迷茫2017-04-17 13:06:46
@brayden 的方法是没有用的,因为这不是标准C/C++的语法
我不知道你为什么一定要用宏,因为你说你用的是C++,显然应该使用模板函数来解决这个问题:
template<typename T>
T Max(T a, T b)
{
return a > b ? a : b;
}
当然了,C++早就考虑过这个问题了,所以你有std::max可以用。