gcc编译错误,对象初始化被解释为函数指针



以下代码:

class Angle {
protected:
   double rad;
   Angle(double r) : rad(r){}
};
class Radian : public Angle {
public:
   Radian(double rad) : Angle(rad){}
};
class Latitude : public Angle {
public:
   Latitude(const Angle&a) : Angle(a){}
   Latitude operator-(const Latitude &other){
      return Latitude(Radian(rad-other.rad));
   }
};
int main(){
   double d = 0.7;
   Latitude lat1(Radian(0.8));
   Latitude lat2(Radian(d*1));
   Latitude lat3(Radian(d));
   Latitude diff2 = lat1 - lat2;
   Latitude diff3 = lat1 - lat3;
   return 0;
}

给出编译器错误:

$ g++ bug.cpp
bug.cpp: In function ‘int main()’:
bug.cpp:26:26: error: no match for ‘operator-’ (operand types are ‘Latitude’ and ‘Latitude(Radian)’)
    Latitude diff3 = lat1 - lat3;
                          ^
bug.cpp:26:26: note: candidate is:
bug.cpp:15:13: note: Latitude Latitude::operator-(const Latitude&)
    Latitude operator-(const Latitude&l){
             ^
bug.cpp:15:13: note:   no known conversion for argument 1 from ‘Latitude(Radian)’ to ‘const Latitude&’

如果我尝试执行lat3 - lat3,它将给出此错误,表明它将lat3解释为函数指针:

error: ISO C++ forbids using pointer to a function in subtraction [-fpermissive]
lat3 - lat3;
       ^

lat2 - lat2正常。

那么这里发生了什么?为什么lat2和lat3被解释为不同的类型?错误消息中Latitude(Radian)的确切含义是什么?

编译器输出来自gcc 4.9.1,在gcc 4.1到4.9版本中也获得了类似的结果。平台是64位RHEL6。

将行更改为:

Latitude lat3((Radian(d)));

你遇到的问题被称为

http://en.wikipedia.org/wiki/Most_vexing_parse

最新更新