templates – 折叠后如何获得标准mpl序列

如果我使用boost :: mpl,让我们看看下面的代码:

typedef fold<
  vector<long,float,long>
, set0<>
, insert<_1,_2>
>::type s;

BOOST_MPL_ASSERT_RELATION( size<s>::value, ==, 2 );

如何将s转换为类型t = boost :: mpl :: set< long,float>再次,这样我就可以使用t来选择一个部分专用的模板函数(在boost :: mpl :: set“上),它提取元素类型并将其转换为std :: tuple< long,float> .这是另一回事

最佳答案
这是一个完整的例子.我称之为元函数统一,但显然你可以随意调用它.
它的工作原理非常简单,它只是一次一个地从输入序列中删除元素,并构建一个可变列表并在最后将它们转储到所需的序列类型中.

    #include <boost/mpl/set.hpp>
    #include <boost/mpl/front.hpp>
    #include <boost/mpl/size.hpp>
    #include <boost/mpl/insert.hpp>
    #include <boost/mpl/erase_key.hpp>
    #include <tuple>

    template <template <class...> class OutSeqType,
              class Sequence,
              std::size_t nSeqSize,
              class ... Elements>
    struct Unify
    {
        typedef typename boost::mpl::front<Sequence>::type Next;
        typedef typename Unify<
            OutSeqType,
            typename boost::mpl::erase_key<Sequence, Next>::type,
            nSeqSize - 1, Next, Elements...>::type type;
    };

    template <template <class...> class OutSeqType,
              class Sequence,
              class ... Elements>
    struct Unify<OutSeqType, Sequence, 0ul, Elements...>
    {
        typedef OutSeqType<Elements...> type;
    };

    int main()
    {
        typedef boost::mpl::insert<
            boost::mpl::insert<
                boost::mpl::insert<
                    boost::mpl::set<>,
                    int>::type,
                float>::type,
            int*>::type Set;

        typedef Unify<
            std::tuple,
            Set,
            boost::mpl::size<Set>::type::value
            >::type Set2;

        //This compile error will print the type of Set2
        Set2::asdfl;
    }

出于某种原因,我不确定我不能在一个集合上使用pop_front,所以我使用了erase_key.这将它限制为关联容器,但它可以推广到任何类型的容器,只需要更多的工作.我会把它留作练习.

转载注明原文:templates – 折叠后如何获得标准mpl序列 - 代码日志