我有以下情形:C++模板扣除不能推断出模板参数
struct AP;
struct B
{
B() : m(2) {}
int m;
};
struct A : private B
{
A() : B(), n(1) {}
private:
int n;
friend AP;
};
struct AP
{
AP(A& a) : a_(a) {}
template<typename T>
struct A_B {
using type = typename std::enable_if< std::is_base_of< typename std::remove_reference<T>::type,
A >::value,
T >::type;
};
template<typename T>
operator typename A_B<T>::type()
{
return static_cast<T>(a_);
}
template<typename T>
typename A_B<T>::type get()
{
return static_cast<T>(a_);
}
int& n() { return a_.n; }
private:
A& a_;
};
int main()
{
A a;
AP ap(a);
ap.n() = 7;
const B& b = ap.get<const B&>();
//const B& b = ap; candidate template ignored: couldn't infer template argument 'T'
//auto b = static_cast<const B&>(ap); candidate template ignored: couldn't infer template argument 'T'
std::cout<<b.m;
}
注释行不会进行编译。 Clang ++注意到“候选模板被忽略:无法推断模板参数'T'”
为什么我无法使用演算操作符获得对A的基础的引用? 我认为代码看起来会更好。
你的注释行尝试转换'ap'进式B'的''同时参考ap'类型为'AP',与'B'和'A'无关。你期望如何工作? – wasthishelpful
@wasthishelpful:我认为OP试图做的是将'AP'实例的'a_'成员转换为'B',这应该是有效的,因为'A'从'B'派生。 – AndyG