别名模板参数包

时间:2017-12-23 00:25:17

标签: c++ templates parameter-passing variadic-templates type-alias

预戏剧

您好, 也许这个问题是重复的,但我对模板编程相对较新,实际上我找不到简单简短解决方案( - >只查找兆字节数" roxxor-template-magic "我不明白)匹配我的具体而简单的问题,所以我觉得现在有点迷失。

预信息

我想使用" type_container"作为类的模板参数。容器是一个简单的结构,它还应该包含一些模板参数包的 typedef

问题:(与底部示例相关)

如何在容器结构中定义和别名类型列表,以及如何访问它们并将它们转发到工厂类中所需的实体? (没有提升,只有C ++ 11/14/17

示例:(编译,如果我知道解决方案)

#include <map>
#include <vector>
#include <string>
#include <stack>

struct MY_TYPE_CONTAINER
{
    using TYPE_MAP            = std::map<int, int>;
    using TYPE_VECTOR         = std::vector<double>;
    using PARAMETER_PACK1 = //? -> ...T -> int, std::stack<int>, int
    using PARAMETER_PACK2 = //? -> ...T -> double, int, std::string
};

template <typename TYPES>
struct Factory
{
    typename TYPES::TYPE_MAP                       m_map;
    typename TYPES::TYPE_VECTOR                    m_vector;
    typename std::tuple<TYPES::PARAMETER_PACK1...> m_tuple;
    typename std::tuple<std::shared_ptr<TYPES::PARAMETER_PACK1>...> m_tuple2;
    void handlePack2(TYPES::PARAMETER_PACK2... args) { }
};


int main()
{
    Factory<MY_TYPE_CONTAINER> oStaticFactory;
    oStaticFactory.handlePack2(2.0, 1, "hi");
    return 0;
}

目前(最佳?)详细解决方案(可编辑)(基于John Zwinck的答案)

#include <map>
#include <vector>
#include <string>
#include <stack>
#include <memory>

struct MY_TYPE_CONTAINER
{
    using TYPE_MAP                    = std::map<int, int>;
    using TYPE_VECTOR                 = std::vector<double>;
    using PARAMETER_PACK1             = std::tuple<int, std::stack<int>, int>;
    using PARAMETER_SHARED_PTR_PACK_1 = std::tuple<std::shared_ptr<int>, std::shared_ptr<std::stack<int>>, std::shared_ptr<int>>;
    using PARAMETER_PACK2             = std::tuple<double, int, std::string>;
};

template <typename TYPES>
class Factory
{
    typename TYPES::TYPE_MAP                    m_map;
    typename TYPES::TYPE_VECTOR                 m_vector;
    typename TYPES::PARAMETER_PACK1             m_tuple;
    typename TYPES::PARAMETER_SHARED_PTR_PACK_1 m_tuple2;

    void handlePack2Impl(typename TYPES::PARAMETER_PACK2 tup) {};

public:
    template <typename... Args>
    void handlePack2(Args... args) { handlePack2Impl(std::make_tuple(args...)); }
};

int main()
{
    Factory<MY_TYPE_CONTAINER> oStaticFactory;
    oStaticFactory.handlePack2(2.0, 1, "hi");
    return 0;
}

2 个答案:

答案 0 :(得分:2)

您实际上可以使用tuple

using PARAMETER_PACK1 = std::tuple<int, std::stack, int>;
using PARAMETER_PACK2 = std::tuple<double, int, std::string>;

typename TYPES::PARAMETER_PACK1 m_tuple;

然后你有一个问题 - 如何宣布这样的事情:

void handlePack2(TYPES::PARAMETER_PACK2... args);

也许:

void handlePack2Impl(typename TYPES::PARAMETER_PACK2 tup);

template <typename... Args>
void handlePack2(Args... args) { handlePack2Impl(std::make_tuple(args...)); }

有关更多想法,请从此处开始:Tuple to parameter pack(但要注意,有模板元编程!

答案 1 :(得分:1)

基本上你不能这样做。你可以做的最接近的事情是保存std::tuple<type, type, type>(或你自己的variadic_class<type, type, type>可能有空身体),然后通过小模板魔法检索列表