(void) (&_x == &_y)的作用

在阅读宋宝华的《Linux设备驱动开发详解》一书时,看到下面这段代码:

cpp 复制代码
#define min(x, y) ({        \
const typeof(x) _x = (x);   \
const typeof(y) -y = (y);   \
(void) (&_x == &_y);        \
_x < _y ? _x : _y;  })

这段代码可以理解如下:

(1)先赋值再比较,可以避免一般宏定义的副作用。

(2)用 const 可以提高可读性。

(3)代码 "(void) (&_x == &_y);" 的作用,是检查 _x 与 _y 的类型是否一致。

(4)添加 void 可以避免编译器弹出无意义的警告(因为其后面的地址比较的结果并没有使用)。

怎样理解第(3)点呢?

比如下面的这一段代码:

cpp 复制代码
int  x = 2;
char y = 3;
int  m = min(x, y);

在编译的时候,编译器会进行下面的判断操作:

cpp 复制代码
int * == char *;

因此编译器会给出警告:

cpp 复制代码
warning: comparison of distinct pointer types lacks a cast

因此 "(void) (&_x == &_y);" 可以检查 _x 与 _y 的类型是否一致,如果不一致则编译器给出警告。

相关推荐
邪修king2 分钟前
C++map_set封装 : 红黑树底层迭代器以及仿函数的运用
android·c语言·数据结构·c++·b树
牟师傅敲代码27 分钟前
第2章:底层时间驱动机制
c++
并不喜欢吃鱼42 分钟前
从零开始 C++------ 十四【C++ 数据结构】unordered_map/unordered_set 全解析:从使用到底层模拟实现
开发语言·数据结构·c++
小欣加油1 小时前
leetcode3633 最早完成陆地和水上游乐设施的时间I
数据结构·c++·算法·leetcode
啦啦啦啦啦zzzz1 小时前
数据结构:二叉排序树(递归与非递归函数的全部实现)
数据结构·c++·二叉排序树
£suPerpanda1 小时前
AtCoder Beginner Contest 453
c++·算法
郝学胜-神的一滴1 小时前
Qt 高级开发 022:栅格布局深度实战
开发语言·c++·qt·软件构建·用户界面
basketball6161 小时前
设计模式入门:3. 装饰器模式详解 C++实现
c++·设计模式·装饰器模式
程序大视界2 小时前
【C++ 从基础到项目实战】C++(三):函数进阶——重载、回调、递归与默认参数
开发语言·c++·cpp
西梅汁2 小时前
C++ 线程间通信(二)
c++