1.简单的宏实现
1
2
| #define max(a,b) (((a) > (b)) ? (a) : (b))
#define min(a,b) (((a) < (b)) ? (a) : (b))
|
2.内核的宏实现
1
2
3
4
5
6
7
8
9
10
11
12
13
14
| /* safe min & max */
/* avoid ++/-- expand twice */
/* compile warning if type diff */
#define min(x, y) ({ \
typeof(x) _min1 = (x); \
typeof(y) _min2 = (y); \
(void) (&_min1 == &_min2); \
_min1 < _min2 ? _min1 : _min2; })
#define max(x, y) ({ \
typeof(x) _max1 = (x); \
typeof(y) _max2 = (y); \
(void) (&_max1 == &_max2); \
_max1 > _max2 ? _max1 : _max2; })
|
Linux 内核的实现是安全的,避免了 ++/– 计算多次,而且会在编译时警告参数为不同的类型
3.使用内联函数实现
1
2
3
4
5
6
7
8
9
10
11
12
13
| // 内联函数要先声明
inline int max(int a, int b);
inline int min(int a, int b);
int max(int a, int b)
{
return (a > b ? a : b);
}
int min(int a, int b)
{
return (a < b ? a : b);
}
|
其实不使用 inline 关键字也可以,因为大多数编译器会自动把短小的函数转成内联类型(手动声明更好)
4.c++ 使用 algorithm 提供的 max/min
1
2
3
4
| #include <algorithm>
std::max(2, 3);
std::min(2, 3);
|