【发布时间】:2018-11-28 16:23:48
【问题描述】:
通常,如果我想通过枚举创建一个模板化(数据)类,我会写这样的东西
enum class Modes : int
{
m1 = 1,
m2 = 2,
m3 = 3
};
template <Modes M>
class DataHolder
{
};
template<>
class DataHolder<Modes::m1>
{
public: int a = 4;
};
然后,如果我想要 Modes::m1 和 Modes::m2 相同的专业化,我会再次编写相同的专业化。有没有办法为多个枚举值编写一个专业化?我已经用 SFINAE 尝试过,但我没有成功。
template <Modes M, typename = void>
class DataHolder
{
};
template<Modes M, typename = typename std::enable_if<M == Modes::m1 || M == Modes::m2>::type>
class DataHolder
{
public: int a = 4;
};
这不会编译。特别是,在我想继续为Modes::m3 进行不同的专业化之后。我在 SO 上尝试了许多类似的解决方案,但似乎没有解决问题。
【问题讨论】:
标签: c++ c++11 templates template-specialization