4
template<typename T>
std::istream & read(std::istream & istr, typename std::enable_if<std::is_pod<T>::value, T>::type & value)
{
    return istr.read( reinterpret_cast<char*>(&value), sizeof(T));
}

int main() 
{
    int x;
    read(cin, x); // error here
}


error C2783: 'std::istream &read(std::istream &,std::enable_if<std::tr1::is_pod<_Ty>::value,T>::type &)' : could not deduce template argument for 'T'

如果我指定 read<int>,它会起作用。有没有办法让它从参数中推断出类型?

4

1 回答 1

15
template<typename T>
std::istream & read(std::istream & istr, T value, 
                    typename std::enable_if<std::is_pod<T>::value>::type* = 0)
{
    return istr.read( reinterpret_cast<char*>(&value), sizeof(T));
}

或者

template<typename T>
typename std::enable_if<std::is_pod<T>::value, std::istream>::type &
read(std::istream & istr, T value)
{
    return istr.read( reinterpret_cast<char*>(&value), sizeof(T));
}

你的原因不起作用是因为如果你知道参数的类型,它不足以确定 T 。如果enable_if是这样的模板呢?

template<int N, typename T> struct A { typedef int type; };

任何T<std::is_pod<T>::value, T>都会这样做。一般来说,由 组成的函数参数类型...T...::type称为非推导上下文,不能用于推导T

于 2010-10-30T18:26:25.167 回答