4

boost::fusion::vector 的编号形式看起来像

template <class T1>
class vector1; 

template<class T1, class T2>
class vector2; 

等等

可变参数形式看起来像

template<class T1 = boost::fusion::void_, class T2 = boost::fusion::void_>
class vector;

那么有没有办法在编译时将 boost::fusion::vector 从编号形式转换为可变参数形式?

4

2 回答 2

2

你真的需要编译时转换吗?两者之间存在运行时转换,所以我看不出需要:

vector2<int, char> a(13, 'b');
vector<int, char> b = a;

然而,我试图玩弄。我对我的答案不满意,但也许你可以努力找到更好的东西。

我希望能够使用一些元功能,但这似乎超出了我的能力范围。此外,使用这种方法,您需要根据不同的值多次定义它。

也许更好的解决方案是首先转换为元组......</p>

#include <boost/fusion/container/vector.hpp>
#include <boost/fusion/container/vector/vector10.hpp>
#include <boost/fusion/include/at.hpp>
#include <boost/type_traits/remove_reference.hpp>
using namespace boost::fusion;

template<typename NumVec2>
struct cast {
    typedef typename result_of::at_c<NumVec2, 0>::type T1;
    typedef typename result_of::at_c<NumVec2, 1>::type T2;
    typedef vector<typename boost::remove_reference<T1>::type, typename boost::remove_reference<T2>::type > type;
};

int main(int, char**){
    vector2<int, char> a(13, 'b');
    typedef cast< vector2<int,char> >::type casted_t;
    casted_t other(10, 'f');
}
于 2012-12-23T22:31:37.720 回答
0

所以看来我有一个答案

using numbered_vector = fusion::vector3<int, char, float>

   struct as_vvector
    {
        template <class T>
        class result;

        template <class Self, class ... Args>
        struct result <Self(Args...)> {
            using type = fusion::vector<
                typename std::remove_reference<Args>::type...>;
        };
    };

    using variadic_vector =
        typename fusion::result_of::invoke<
                    as_vvector, numbered_vector>::type;
于 2012-12-24T12:35:49.883 回答