重载逻辑运算符 && 和 ||从 C++17 开始短路?

问题描述 投票:0回答:1

我阅读了http://en.cppreference.com/w/cpp/language/operators

布尔逻辑运算符、运算符 && 和运算符 ||

与 内置版本,重载不会对其左操作数进行排序 在正确的之前,并且 (C++17 之前) 无法实现短路 评价。

(我的重点)。

找不到任何支持短路的 C++17 资源或代码示例 对于运算符&& 和运算符||。 与C++17参数包折叠表达式有关吗?尝试使用它,但无法为重载运算符 && 和 || 创建短路行为使用 C++17 折叠表达式。

代码:

class A {
    bool val;
public:
    A(bool b) : val(b) { cout << "A born as " << boolalpha << val << endl;}
    template<typename ...Args>
    bool operator&&(Args&&... args) {
        return (val && ... && args.val);
    }    
};

int main() {
    cout << boolalpha;
    cout << ( A{false} && A{true} ) << endl;
    cout << ( A{true} && A{false} ) << endl;
    cout << ( A{false} && A{false} ) << endl;
}

输出:

A born as true
A born as false
false
A born as false
A born as true
false
A born as false
A born as false
false

http://coliru.stacked-crooked.com/a/f0b5325899c2fe6b

注意:从左到右的顺序在使用 C++17 标志编译的当前 gcc 版本中也不会发生。

c++ c++17 operator-overloading short-circuiting
1个回答
14
投票

该声明与短路评估无关。这是关于评估操作数的顺序。

C++17 之前的版本,重载 && 和 || 的操作数求值顺序是编译器定义的。 C++17 为 && 和 || 定义了从左到右的显式求值顺序,无论它们是否重载。

短路评估仍然仅适用于内置运算符。

请注意,在您引用的实际页面上,突出显示的部分是应用于特定版本的部分。那部分是关于排序顺序的,而不是关于短路评估的部分。

© www.soinside.com 2019 - 2024. All rights reserved.