有没有办法对枚举使用替换失败不是错误(SFINAE)?
template <typename T>
struct Traits
{
}
template <>
struct Traits<A>
{
};
template <>
struct Traits<B>
{
enum
{
iOption = 1
};
};
template <T>
void Do()
{
// use Traits<T>::iOption
};
然后,Do<B>();
工作和Do<A>();
失败。但是,当 iOption 不存在时,我可以提供默认行为。所以我把Do to DoOption的一部分分开。
template <typename T, bool bOptionExist>
void DoOption()
{
// can't use Traits<T>::iOption. do some default behavior
};
template <typename T>
void DoOption<T, true>()
{
// use Traits<T>::iOption
};
template <T>
void Do()
{
// 'Do' does not use Traits<T>::iOption. Such codes are delegated to DoOption.
DoOption<T, DoesOptionExist<T> >();
};
现在,缺少的部分是DoesOptionExist<T>
- 一种检查结构中是否存在 iOption 的方法。当然 SFINAE 适用于函数名称或函数签名,但不确定它适用于枚举值。