帶有可變參數模板的 std::function 和 std::forward

0x_阿納金

最近我正在閱讀關於可變參數模板的文章,並根據我在網上看到的一個例子,我試圖實現一個基本的事件系統。到目前為止,它似乎工作正常,但我試圖更進一步,並允許將 N 個參數傳遞給事件處理程序函數/回調,不幸的是,我得到的構建錯誤如下,我不確定我做錯了什麼。我查看了類似的源代碼,但仍然無法弄清楚是什麼問題。

D:\Development\lab\c-cpp\EventEmitter3\src\main.cpp:30:68: error: parameter packs not expanded with '...':
         return std::any_cast<std::function<R(Args)>>(eventCallback)(std::forward<Args>(args)...);
                ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~

D:\Development\lab\c-cpp\EventEmitter3\src\main.cpp:30:68: note:         'Args'

Build finished with error(s).

到目前為止,這是我所擁有的,如果您刪除...事件系統,則事件系統對於main.

#include <any>
#include <string>
#include <iostream>
#include <functional>
#include <unordered_map>

class EventEmitter
{

private:
    std::unordered_map<std::string, std::any> events;

public:
    EventEmitter() {}

    void on(const std::string &eventName, const std::any &eventCallback)
    {
        events[eventName] = eventCallback;
    }

    template <typename R>
    R emit(const std::string &eventName)
    {
        const std::any &eventCallback = events[eventName];
        return std::any_cast<std::function<R(void)>>(eventCallback)();
    }

    template <typename R, typename... Args>
    R emit(const std::string &eventName, Args &&...args)
    {
        const std::any &eventCallback = events[eventName];
        return std::any_cast<std::function<R(Args)>>(eventCallback)(std::forward<Args>(args)...);
    }

    virtual ~EventEmitter() {}
};

int fun1()
{
    std::cout << "fun1" << std::endl;
    return 1;
}

double fun2(int i)
{
    std::cout << "fun2" << std::endl;
    return double(i);
}

double fun3(int x, int y)
{
    std::cout << "fun3" << std::endl;
    return double(x + y);
}

int main(int argc, char *argv[])
{
    EventEmitter e;

    e.on("fun1", std::function<int(void)>(fun1));
    e.on("fun2", std::function<double(int)>(fun2));
    

    e.emit<int>("fun1");
    e.emit<double, int>("fun2", 1);
    
    // Variadic would have been handy right here I guess?
    // e.on("fun3", std::function<double(int, int)>(fun3)); 
    // e.emit<double, int>("fun3", 1, 2); 

    return 0;
}

我怎樣才能解決這個問題?

蘋果 蘋果

嗯,你需要擴展它。

return std::any_cast<std::function<R(Args...)>>(eventCallback)(std::forward<Args>(args)...);
                                     ^^^^^^^

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章