簡體   English   中英

C ++ 11可變參數模板函數存儲

[英]C++11 variadic template function storage

我目前正在將回調系統改編為C ++ 11可變參數模板。 基本上我想做的是存儲一個帶有返回值和任意數量參數的函數。

之后,應調用此函數,並從boost::archive加載參數,並將返回值寫回到另一個存檔中。

#include <string>
#include <map>
#include <iostream>
#include <boost/archive/binary_iarchive.hpp>
#include <boost/archive/binary_oarchive.hpp>

using iarchive = boost::archive::binary_iarchive;
using oarchive = boost::archive::binary_oarchive;
using namespace std;

template<class Interface>
class RFCProvider : public Interface {
    class FuncStore {
    public:
        virtual ~FuncStore() {}
        virtual void call(iarchive& in, oarchive& out) = 0;
    protected:
        template <class T> T read(iarchive& in) { T a; in >> a; return a; }
    };


    template<class Return, class... Args>
    class FuncStoreRetN : public FuncStore {
        public:
            typedef Return(Interface::*Function)(Args... args);
            typedef Return ReturnType;
            static const int ArgCount = sizeof...(Args);
        private:
            struct pass {
                Return res;
                pass(Interface* me, Function func, Args... args) { res = (me->*func)(args...); }
            };

            Interface* mMe;
            Function mFunc;
        public:
            FuncStoreRetN(Interface* me, Function func) : mMe(me), mFunc(func) {}
            void call(iarchive& in, oarchive& out) {
                pass c{mMe, mFunc, read<Args>(in)...};
                out << c.res;
            }
    };


    map<string, FuncStore*> functionStore;
public:
    template<class Return, class... Args>
    void registerFunction(const string& name, Return(Interface::*func)(Args...)) {
        functionStore[name] = new FuncStoreRetN<Return, Args...>(this, func);
    }
};


class TestClass {
public:
    bool foo(int x) { return x == 0; }
};


int main() {
    RFCProvider<TestClass> p;
    p.registerFunction("foo", &TestClass::foo);

    return 0;
}

根據我的理解, pass c{mMe, mFunc, read<Args>(in)...}; 應該擴展以pass c{mMe, mFunc, read<int>(in), read<string>(in), ...}; 我對嗎?

但是我無法用g ++(Ubuntu 4.8.2-19ubuntu1)4.8.2進行編譯

error: expected primary-expression before ‘>’ token
     pass c{mMe, mFunc, read<Args>(in)...};
                                 ^

有什么建議么?

編輯:添加了MCVE

更換

pass c{mMe, mFunc, read<Args>(in)...};

pass c{mMe, mFunc, FuncStore::template read<Args>(in)...};

由於所有這些都是通過類模板中的嵌套類(和類模板)發生的,因此依賴名稱查找將適用,並且您必須為編譯器添加通常的說明。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM