0

我怎样才能使这个递归变体起作用?我想要一个变体容器或变体容器容器。

template <class T>
class A 
{ 
    // ...
    T t_;
};

template <class T>
class AVariant
{
    typedef typename boost::make_variant_over<T>::type Type;
    Type t;

    // ...
};

template <class Container>
class Composite
{
    typedef typename Container::value_type T;
    Container container_of_any_;

    // ....
};

在 main.cpp 中:

typedef AVariant<boost::mpl::list<
    A<int>,
    A<long>,
    boost::recursive_wrapper<Composite<std::vector<Any> > > // Compile error: 'Any' is not declared in this scope
> > Any;

我知道 Compoiste > 是不对的,但不知道怎么做?

编辑:我更改了以下内容:

template <class T>
class AVariant
{
    typedef typename boost::make_recursive_variant_over<T>::type Type;
    Type t_;

    // ...

    template <class Archive>
    class SerializeVisitor : public boost::static_visitor<>
    {
        SerializeVisitor( Archive& ar ) : ar_(ar) {}
        template <typename U>
        void operator()( const U& t ) const
        {
            ar_ & BOOST_SERIALIZATION_NVP( t );
        }
    };

    friend class boost::serialization::access;
    template<class Archive>
    void serialize( Archive& ar, const unsigned int version )
    {
        boost::apply_visitor( SerializeVisitor<Archive>( ar ), t_ );
    }

};

然后使用实例化:

typedef AVariant<boost::mpl::list<
    A<double>,
    A<int>,
    std::vector<boost::recursive_variant_> // to make the recursion slightly simplier
> > Any;

而且我的 AVariant 有一个访问者可以像上面那样序列化。在 main() 中调用序列化时,它仍然会给出编译错误。它似乎在错误中寻找类 std::vector 的 serialize() 函数:

const class std::vector<boost::variant<boost::detail::variant::recursive_flag<boost::detail::variant::over_sequence<boost::mpl::vector<A<double>, A<long int>, A, std::vector<boost::recursive_variant_, std::allocator<boost::recursive_variant_> >, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na> > >, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_>, std::allocator<boost::variant<boost::detail::variant::recursive_flag<boost::detail::variant::over_sequence<boost::mpl::vector<A<double>, A<long int>, A, std::vector<boost::recursive_variant_, std::allocator<boost::recursive_variant_> >, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na> > >, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_, boost::detail::variant::void_> > >' has no member named 'serialize'
4

1 回答 1

1

你需要在其中使用boost::make_recursive_variant而不是boost::recursive_wrapperwith boost::recursive_variant_。所以你应该试试这个:

typedef AVariant<boost::mpl::list<
A<int>,
A<long>,
boost::make_recursive_variant<Composite<std::vector<boost::recursive_variant_> > 
  >::type > > Any;

这可以帮助你。

你应该参考这里: http: //www.boost.org/doc/libs/1_54_0/doc/html/variant/tutorial.html#variant.tutorial.recursive.recursive-variant 和这里http://www.boost。 org/doc/libs/1_54_0/boost/variant/recursive_variant.hpp有关递归变体的更多信息。如果要序列化变体,最好使用boost::variant访问机制来写出变体中包含的实际类型:

 variant_serializer ser;
 boost::apply_visitor( ser, your_variant);
于 2013-07-16T06:20:23.030 回答