制作一个指向两个函数c ++的std :: funtion

Jul*_*ian 1 c++ std-function

如果我有两个功能

void foo()
{
    std::cout << 1 << std::endl;
}

void bar()
{
    std::cout << 2 << std::endl;
}
Run Code Online (Sandbox Code Playgroud)

我有一个函数指针

std::function<void()> v;
Run Code Online (Sandbox Code Playgroud)

我想要v()打印

1
2
Run Code Online (Sandbox Code Playgroud)

Dai*_*Dai 5

std::function目标的定义是const T* target() const,这意味着它只能存储一个目标.

之前已经提出过这个问题,您所描述的情况在事件处理程序的上下文中称为CLR/.NET中的"委托多播".

有几种可能的解决方案:

  1. 第一种是使用lambda或其他函数手动定义多播:

    function<void()> v = []() {
        foo();
        bar();
    };
    v();
    
    Run Code Online (Sandbox Code Playgroud)
  2. 第二个是定义你自己的完整std::function版 - 它支持可变数量的目标.您可以使用template数组(因此避免运行时使用vector)...或者只是使用一个数组vector.

  3. 第三种选择是简单地换行vector(警告:伪代码):

    template<class FuncType>
    class MulticastFunction {
    private:
        vector<std::function<FuncType>> targets;
    public:
        void operator()() {
            for(auto& target : this->targets) {
                target();
            }
        }
        void addTarget(FuncType& target) {
            this->targets->push_back( target );
        }
    }
    
    Run Code Online (Sandbox Code Playgroud)

    用法:

    MulticastFunction<void()> mc;
    mc.addTarget( foo );
    mc.addTarget( bar );
    mc();
    
    Run Code Online (Sandbox Code Playgroud)