用于将struct类型映射到枚举的C++模板?

chr*_*irk 2 c++ enums templates struct map

我有类似的东西:

struct A { ... };
struct B { ... };
struct C { ... };

class MyEnum {
public:
    enum Value { a, b, c; }
}

template<typename T> MyEnum::Value StructToMyEnum();

template<>
MyEnum::Value StructToMyEnum<A>()
{
   return MyEnum::a;
}

template<>
MyEnum::Value StructToMyEnum<B>()
{
   return MyEnum::b;
}
Run Code Online (Sandbox Code Playgroud)

我基本上想a通过调用soemthing直接获得

StructToMyEnum<A>();
Run Code Online (Sandbox Code Playgroud)

这是我能想到的最好的,但是当我编译时,我multiple definition of 'MyEnum::Value StructToMyEnum<A>()'在尝试链接时遇到错误.

有关根据此示例将类型映射到枚举的最佳方法的任何建议吗?

jon*_*son 8

您可以在编译时将类型映射到枚举:

#include <iostream>

struct A { int n; };
struct B { double f; };
struct C { char c; };

class MyEnum
{
public:
    enum Value { a, b, c };
};

template<typename T> struct StructToMyEnum {};

template<> struct StructToMyEnum<A> {enum {Value = MyEnum::a};};
template<> struct StructToMyEnum<B> {enum {Value = MyEnum::b};};
template<> struct StructToMyEnum<C> {enum {Value = MyEnum::c};};

int main (int argc, char* argv[])
{
    std::cout << "A=" << StructToMyEnum<A>::Value << std::endl;
    return 0;
}
Run Code Online (Sandbox Code Playgroud)


Edw*_*nge 5

多个定义是因为您需要添加inline关键字或将特化的实现推送到cpp文件中,只在头文件中留下这样的声明.

你可以使用mpl :: map来编写一个通用版本.像这样的东西:

struct A {};
struct B {};
struct C {};

enum Value { a,b,c };

template < typename T >
Value get_value()
{
  using namespace boost::mpl;
  typedef mpl::map
  < 
    mpl::pair< A, mpl::int_<a> >
  , mpl::pair< B, mpl::int_<b> >
  , mpl::pair< C, mpl::int_<c> >
  > type_enum_map;

  typedef typename mpl::at<type_enum_map, T>::type enum_wrap_type;

  return static_cast<Value>(enum_wrap_type::value);
}
Run Code Online (Sandbox Code Playgroud)