这个问题与我最后的one有关。我正在尝试使用traits<T>
和traits<T*>
解决问题。请考虑下面的代码。在C++中使用特征
template<typename T>
struct traits
{
typedef const T& const_reference;
};
template<typename T>
struct traits<T*>
{
typedef const T const_reference;
};
template<typename T>
class test
{
public:
typedef typename traits<T>::const_reference const_reference;
test() {}
const_reference value() const {
return f;
}
private:
T f;
};
int main()
{
const test<foo*> t;
const foo* f = t.value(); // error here. cannot convert ‘const foo’ to ‘const foo*’ in initialization
return 0;
}
所以它看起来像编译器不考虑指针性状专业化和服用value()
返回类型为const foo
,而不是const foo*
。我在这里做错了什么?
任何帮助将是伟大的!
我觉得dump :(但是,T本身就是一个指针('foo *')。所以指定'T *'会导致'T **'? – 2010-02-21 04:48:56
不。在'traits'专精中,T '不是指针,'T *'是一个指针,你使用相同的typename参数是不重要的。 –
outis
2010-02-21 04:51:39
好的,谢谢。 – 2010-02-21 04:54:59