Boost::signals2::signal输出错误

boost::signals2::signal gives wrong output?

本文关键字:错误 输出 signals2 Boost signal      更新时间:2023-10-16

我是boost库的新手,在练习绑定示例时,我编写了以下代码。但是,看起来"res"是正确计算的,但是,正确的结果没有传回信号。请帮助,什么是错误的在下面的片段。代码在http://cpp.sh/

上编译并运行。
#include <iostream>
#include<boost/signals2.hpp>
using namespace std;
class MathObject{
public:
    int AddOps(int op1, int op2);
};
int MathObject::AddOps(int op1, int op2){
    int res = op1 + op2;
    cout << "Result of AddOps: " << res << endl;
    return res;
}
int main(void){
    MathObject mObj;
    boost::signals2::signal<int(int)> incrementer;
    incrementer.connect(boost::bind(&MathObject::AddOps, &mObj, 1, _1));
    boost::signals2::signal<int(int)> doubler;
    doubler.connect(boost::bind(&MathObject::AddOps, &mObj, _1, _1));
    cout << "Incrementer of 5" << incrementer(5) << endl;
    cout << "Doubler of 5" << doubler(5) << endl;
}
输出:

Result of AddOps: 6
Incrementer of 51
Result of AddOps: 10
Doubler of 51

当一个信号被调用时,它可能有也可能没有任何处理程序连接到它。因此,它可能产生结果,也可能不会产生结果。默认行为是返回最后连接的处理程序的结果(如果有的话);或者返回一个表示"无结果"的值。因此,incrementer(5)doubler(5)的返回值不是int,而是boost::optional<int>

这会导致您观察到的输出,因为boost::optional<int>可以隐式地转换为bool,然后再转换为10的输出。

您需要首先检查结果是否存在,然后从返回的boost::optional<int>中获取结果:

#include <iostream>
#include<boost/signals2.hpp>
using namespace std;
class MathObject{
public:
    int AddOps(int op1, int op2);
};
int MathObject::AddOps(int op1, int op2){
    int res = op1 + op2;
    cout << "Result of AddOps: " << res << endl;
    return res;
}
int main(void){
    MathObject mObj;
    boost::signals2::signal<int(int)> incrementer;
    incrementer.connect(boost::bind(&MathObject::AddOps, &mObj, 1, _1));
    boost::signals2::signal<int(int)> doubler;
    doubler.connect(boost::bind(&MathObject::AddOps, &mObj, _1, _1));
    boost::optional<int> incremented = incrementer(5);
    if (incremented) {
        cout << "Incrementer of 5: " << *incremented << endl;
    }
    boost::optional<int> doubled = doubler(5);
    if (doubled) {
        cout << "Doubler of 5: " << *doubled << endl;
    }
}

如果您查看boost::signals2的文档,默认情况下它返回最后执行的信号返回的值。但它不是一个普通的值-它被包装在boost::optional中,因为可能没有信号连接到插槽,没有合理的值返回。

boost::optional可转换为bool,这就是当你输出它时发生的事情-它输出1,这意味着它确实有一个值。如果您输入的是cout << incrementer(5).get(),您将得到您所期望的输出