#define SIZE 10
// 第一个版本, 安全性保护
// 出错代码 MAXV(5, 3) + 10 应该计算出15, 实际计算出 5
// 上面代码实际编译代码为 5 > 3 ? 5 : 3 + 10
//#define MAXV(A, B) A > B ? A : B
// 第二个版本, 解决上面测试代码的bug
//#define MAXV(A, B) (A > B ? A : B)
// 第三个版本, 通过每个替换元素外面加括号, 解决上面版本的bug
//#define MAXV(A, B) ((A) > (B) ? (A) : (B))
// 第四个版本,通过赋值扩展解决符号多次替换的问题
//#define MAXV(A, B) ({int __a = (A); int __b = (B); __a > __b ? __a : __b;})
// 通过__typeof__()获取数据类型解决灵活性(只能处理int类型)的问题
//#define MAXV(A, B) ({__typeof__(A) __a = (A); __typeof__(B) __b = (B); __a > __b ? __a : __b;})
// 连接两个标识符的宏
#define __PASTE__(A, B) A##B
//
#define __MAXV_IMPL__(A, B, L) ({__typeof__(A) __PASTE__(a, L) = (A); __typeof__(B) __PASTE__(b, L) = (B); __PASTE__(a, L) > __PASTE__(b, L) ? __PASTE__(a, L) : __PASTE__(b, L);})
#define MAXV(A, B) __MAXV_IMPL__(A, B, __COUNTER__)
#define __MINV_IMPL__(A, B, L) ({__typeof__(A) __PASTE__(a, L) = (A); __typeof__(B) __PASTE__(b, L) = (B); __PASTE__(a, L) < __PASTE__(b, L) ? __PASTE__(a, L) : __PASTE__(b, L);})
#define MINV(A, B) __MINV_IMPL__(A, B, __COUNTER__)
int main(int argc, const char * argv[]) {
return 0;
}