如何解决 boost::signals2 的slot_type和 boost::bind 的歧义,为什么它甚至模棱两可?

How can I resolve ambiguity of boost::signals2's slot_type and boost::bind, and why is it even ambiguous?

本文关键字:boost 歧义 bind 为什么 模棱两可 何解决 解决 slot signals2 type      更新时间:2023-10-16

考虑这个例子:

#include <boost/signals2/signal.hpp>
#include <boost/bind.hpp>
typedef boost::signals2::signal< void ( double ) > DoubleSignalType;
typedef boost::signals2::signal< void ( void ) >   VoidSignalType;
class B {
public:
    void connect( DoubleSignalType::slot_type dbl_slot ) {
        dbl_sig.connect( dbl_slot );
    }
    void connect( VoidSignalType::slot_type void_slot ) {
        void_sig.connect( void_slot );
    }
private:
    DoubleSignalType dbl_sig;
    VoidSignalType void_sig;
};
class A {
public:
    void foo( double a ) {};
    void bar( void ) {};
    void other(){
        B b;
        b.connect( boost::bind( &A::foo, this, _1 ) );
    }
};
int main( int argc, char* argv[] ) { return 0; }

当我编译这个时,我得到:

g++ x.cpp
x.cpp: In member function ‘void A::other()’:
x.cpp:27:53: error: call of overloaded ‘connect(boost::_bi::bind_t<void, boost::_mfi::mf1<void, A, double>, boost::_bi::list2<boost::_bi::value<A*>, boost::arg<1> > >)’ is ambiguous
x.cpp:27:53: note: candidates are:
x.cpp:9:10: note: void B::connect(boost::signals2::signal1<void, double, boost::signals2::optional_last_value<void>, int, std::less<int>, boost::function<void(double)>, boost::function<void(const boost::signals2::connection&, double)>, boost::signals2::mutex>::slot_type)
x.cpp:13:10: note: void B::connect(boost::signals2::signal0<void, boost::signals2::optional_last_value<void>, int, std::less<int>, boost::function<void()>, boost::function<void(const boost::signals2::connection&)>, boost::signals2::mutex>::slot_type)

有别的办法吗?

你必须做一些更复杂的事情,因为boost::bindoperator()是模板,并且有任意数量的参数(能够调用没有参数的函数,因为它有一些)。

如果你提供非重载的方法,一切都没问题

一个简单的解决方案是显式地创建所需的信号类型。例如:

    b.connect( DoubleSignalType::slot_type( boost::bind( &A::foo, this, _1 ) ) );