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);