int转bool是隐式转换,值为0时转false,非0(含负数、大数)均转true;推荐static_cast显式转换,避免!!x等不安全写法;整型、浮点型转bool规则统一,仅判零值,无性能开销。

int 转 bool 是隐式转换,但行为很固定
在 C++ 里,int 到 bool 不需要写 static_cast 或函数调用,编译器自动处理:值为 0 时转成 false,非 0(无论正负、大小)都转成 true。这不是“四舍五入”或“截断”,而是纯逻辑判别。
常见错误现象:
- 把 -1 当成 false(实际是 true)
- 认为 255 比 1 “更 true”(其实没有程度之分,bool 只有两态)
使用场景多见于条件判断:if (x)、while (status_code),底层就是走这套转换规则。
- 所有非零
int都等价于true,包括-1、INT_MAX、42 -
0是唯一映射到false的整数值 - 转换不改变原变量,也不触发任何构造或析构
显式转换写法有哪些?该选哪个?
虽然隐式转换合法,但有些场景你得主动写出来,比如函数重载歧义、模板推导失败,或者团队代码规范强制显式。
三种写法效果完全一致,但可读性和兼容性略有差异:
立即学习“C++免费学习笔记(深入)”;
-
static_cast<bool>(x)</bool>:最推荐。类型安全,语义明确,C++11 起通用 -
!!x:老派写法,靠两次取反实现,可读性差,容易被误读为“逻辑非非”,且对带副作用的表达式(如func())会执行两次 -
bool(x):函数风格转型,C++98 就支持,但和static_cast相比,在模板中可能引发意外的用户定义转换
示例:
int x = -5;<br>bool b1 = x; // 隐式,合法<br>bool b2 = static_cast<bool>(x); // 显式,推荐<br>bool b3 = !!x; // 不推荐,尤其 x 是函数调用时危险
和 C 语言、C++ 其他整型的转换规则一样吗?
规则完全一致:所有整数类型(char、short、long long、unsigned int 等)转 bool,都只看是否为零值。
但要注意几个易踩的坑:
-
unsigned int没有负数,所以只要不是0就一定是true;而int的负值也转true,这点常被忽略 - C 语言里没有
bool关键字(C99 才有_Bool),用stdbool.h的bool实际是_Bool别名,转换逻辑和 C++ 一致 - 浮点数转
bool同样适用“零值 →false”,但0.0和-0.0都算零,这点和整数无差别
性能和 ABI 兼容性几乎不用操心
这个转换在编译期就确定了,生成的汇编通常就是一条比较指令(比如 test eax, eax)或直接复用寄存器的零标志位,没有任何运行时开销。
它不涉及内存分配、函数调用或类型擦除,所以:
- 在嵌入式或实时系统中完全放心用
- 跨平台(x86/ARM/RISC-V)、跨标准(C++11/14/17/20)行为完全一致
- 和
std::vector<bool></bool>这种特化容器无关——那是存储优化,不影响转换逻辑
真正要小心的,是把“非零即真”的直觉,错当成“值越大越可信”。比如用 errno 返回码做 if (errno) 判断错误发生,是对的;但拿它当严重程度指标,就错了。










