0

我正在尝试使用稍后在项目中为每个观察者添加新功能所需的捕获来实现观察者模式。

class Obsevers {
public:
    virtual ~Obsevers() {}
};

class TestObserver : public Obsevers {
public:
    void print1(int i) {
        std::cout << i << std::endl;
    }
};

class TestObserver2 : public Obsevers {
public:
    void print2(int i, char c) {
        std::cout << i << " , " << c << std::endl;
    }
    //possible new functions here later
};

我的通知方法如下:

template<typename Type, typename Notify>
void NotifyObserver(Notify notify) {
    typedef std::list<Obsevers*>::iterator iter;
    iter it = m_observers.begin();
    iter end = m_observers.end();
    for(; it != end; ++it) {
        Type * o = dynamic_cast<Type*>(*it);
        if(o == NULL) continue;
        notify(o);
    }
}

调用通知代码如下。

NotifyObserver<TestObserver2>(boost::bind(&TestObserver2::print2, _1, 32, 'b'));

现在给出上述代码块的上下文,我的问题是使用占位符(_1)作为绑定中的对象参数正确还是这种未定义的行为?

关于 bind 的 boost 文档没有指定仅对函数参数使用对象的占位符。

4

1 回答 1

1

你的代码是正确的。

Boost.Bind文档表明您的代码

boost::bind(&TestObserver2::print2, _1, 32, 'b')

是相同的

boost::bind<void>(boost::mem_fn(&TestObserver2::print2), _1, 32, 'b')

whereboost::mem_fn负责调用指向成员函数的指针。只要绑定的对象boost::mem_fn使用可以使用的东西(例如指针或引用)进行评估,它就会正确地调用该函数。

于 2012-09-25T21:12:21.973 回答