如何检查模板类型是否是变体类型的类型之一?

时间:2016-05-31 07:02:33

标签: c++ boost typetraits c++98 boost-variant

考虑到变体类型和模板函数,如何检查模板类型是变体的类型之一?是否有比以下更优雅的方式?

typedef boost::variant<Foo,Bar> Var;

template <typename T>
void f(const T& x)
{
  BOOST_STATIC_ASSERT(
       boost::is_same<T,Foo>::value
    || boost::is_same<T,Bar>::value
  );
}

注意:我使用Boost 1.57和gcc 4.8.3。 我不使用C ++ 11 与旧gcc版本兼容。

1 个答案:

答案 0 :(得分:8)

使用MPL:

#include <boost/variant/variant.hpp>
#include <boost/mpl/contains.hpp>

typedef boost::variant<Foo,Bar> Var;

template <typename T>
void f(const T& x)
{
    BOOST_STATIC_ASSERT(boost::mpl::contains<Var::types, T>::value);
}

DEMO

或手动迭代boost:::variant种类型:

#include <boost/variant/variant_fwd.hpp>
#include <boost/type_traits.hpp>

template <typename T, typename V>
struct variant_has_type;

template <typename T, BOOST_VARIANT_ENUM_SHIFTED_PARAMS(typename Ts)>
struct variant_has_type<T, boost::variant<T, BOOST_VARIANT_ENUM_SHIFTED_PARAMS(Ts)> > : boost::true_type {};

template <typename T, typename U, BOOST_VARIANT_ENUM_SHIFTED_PARAMS(typename Ts)>
struct variant_has_type<T, boost::variant<U, BOOST_VARIANT_ENUM_SHIFTED_PARAMS(Ts)> > : variant_has_type<T, boost::variant<BOOST_VARIANT_ENUM_SHIFTED_PARAMS(Ts), void> > {};

template <typename T, BOOST_VARIANT_ENUM_SHIFTED_PARAMS(typename Ts)>
struct variant_has_type<T, boost::variant<void, BOOST_VARIANT_ENUM_SHIFTED_PARAMS(Ts)> > : boost::false_type {};

DEMO 2