短路求值是C++标准强制规定的行为:&&左侧为false时跳过右侧,||左侧为true时跳过右侧;用于避免空指针解引用等错误,但会使右侧副作用不执行。

短路求值(Short-circuit Evaluation)是指 C++ 中逻辑与 && 和逻辑或 || 运算符在确定整体结果后,**不再计算右侧操作数**的行为。这不是优化技巧,而是语言标准强制规定的求值顺序和行为,直接影响程序正确性与性能。
短路规则:什么时候不执行右边?
&&:左边为 false 时,整个表达式必为 false,跳过右边;
||:左边为 true 时,整个表达式必为 true,跳过右边。
例如:
int* p = nullptr;
if (p != nullptr && p->value > 0) { ... } // 安全:p 为空时不会解引用
if (p->value > 0 && p != nullptr) { ... } // 危险:先解引用空指针,未定义行为!效率陷阱:副作用被跳过,可能出乎意料
如果右侧表达式有副作用(如函数调用、自增、IO),短路会导致这些副作用**完全不发生**——这常被误认为“bug”,实则是符合标准的预期行为。
立即学习“C++免费学习笔记(深入)”;
if (x > 0 && log("x is positive"), x :当x 时,log()根本不执行-
while (iter != end && *iter++ != target):若iter == end,*iter++不执行,避免越界;但若顺序颠倒,就崩溃 - 误用
&/|(位运算符)替代&&/||:它们无短路,总执行两边,且优先级不同,易引发隐晦错误
与布尔转换、序列点的关系
&& 和 || 是**带序列点的内置运算符**:左操作数求值完成、且是否求右操作数已决定后,才进入下一步。这意味着:
- 左操作数的所有副作用(如
i++)一定在判断是否执行右边前完成 - 右操作数的求值(含其副作用)严格晚于左操作数的完成
- 这是实现安全条件判断(如指针检查 + 解引用)的语言级保障
自定义类型重载时的注意事项
若对类类型重载 operator&& 或 operator||,**短路行为将丢失**——因为重载后它们变成普通函数调用,两个参数必须先求值才能传入。
- 标准库明确禁止重载内置逻辑运算符以保持短路语义
- 若真需重载,应清楚意识到:它不再是逻辑运算符,而是普通二元函数,且失去短路、序列点和内置优先级
- 实践中,绝大多数情况不应重载
&&/||;用 if 分支或显式函数更清晰安全
基本上就这些。短路不是“编译器优化”,而是 C++ 表达式求值模型的核心部分——理解它,才能写出既高效又健壮的条件逻辑。










