如何在转换运算符中使用std :: enable_if?

时间:2013-08-07 09:56:27

标签: c++ metaprogramming sfinae enable-if

基本上我希望我的范围类型可以从Range<const char>隐式转换为Range<const unsigned char>。 std :: enable_if似乎不可能,因为该函数不带参数且没有返回。是什么工作?

这基本上是我尝试过的:

template<typename T>
class Range{
    T* begin_;
    T* end_;
public:
    Range(T* begin,T* end):begin_{begin},end_{end}{}
    template<int N>
    Range(T (&a)[N]):begin_{static_cast<T*>(&a[0])},end_{static_cast<T*>(&a[N-1])}{}
    T* Begin(){return begin_;}
    T* End(){return end_;}
    operator typename std::enable_if<std::is_same<T,const char>::value,Range<const unsigned char>&>::Type (){
        return *reinterpret_cast<Range<const unsigned char>*>(this);
    }
};

1 个答案:

答案 0 :(得分:11)

使其成为一个模板,其默认参数默认为T - 这是将类型推导推迟到函数实例化的点,否则为SFINAE doesn't work。然后在另一个参数的默认值中进行所需的检查。

template<
    typename U = T,
    typename = typename std::enable_if< std::is_same<U,const char>::value >::type
>
operator Range<const unsigned char>() {
    return *reinterpret_cast<Range<const unsigned char>*>(this);
}