这是link的后续帖子
我创建了两个类RadAngle和DegAngle,后者是从前者继承的。由于我想避免代码重复,因此我将DegAngle继承自RadAngle。
注意到在RadAngle中,我想
class RadAngle {
...
RadAngle toRad(const DegAngle& dang) {.. do something..} // <-- child class reference
...
}
这可能吗?如果不是,是否有可能用几乎相同的代码重写两个类?
EDIT01:
现在这是我修改的代码,它不使用两个类,而是使用一个类和空结构。但是,我认为它将在toRad,toDeg中创建其他问题,以检查输入类型是否一致。虽然这是未来的工作:P
template<typename Unit, typename numT>
class Angle {
public:
Angle() {
AngVal = 0.0;
}
Angle(const numT& angV) {
AngVal = angV;
}
void operator = (const Angle<Unit,numT>& ang1) {
AngVal = ang1.getVal();
}
Angle operator+(const Angle<Unit,numT>& ang1) const { return Angle<Unit,numT>(AngVal+ang1.getVal()); }
Angle operator-(const Angle<Unit,numT>& ang1) const { return Angle<Unit,numT>(AngVal-ang1.getVal()); }
Angle operator*(const Angle<Unit,numT>& ang1) const { return Angle<Unit,numT>(AngVal*ang1.getVal()); }
Angle operator/(const Angle<Unit,numT>& ang1) const { return Angle<Unit,numT>(AngVal/ang1.getVal()); }
numT getVal() const { return AngVal;};
Angle<Unit,numT> toRad(const Angle<Unit,numT>& dang) { return dang.getVal() / 180. * M_PI;}
Angle<Unit,numT> toDeg(const Angle<Unit,numT>& dang) { return dang.getVal() / M_PI * 180.;}
private:
numT AngVal;
};
struct Radian;
struct Degree;
int main() {
Angle<Radian,float> a(1.5);
Angle<Radian,float> b(3.5);
Angle<Radian,float> c = a+b;
//std::cout << c << std::endl;
printf("%.2f\n",c.getVal());
Angle<Degree,float> d(45.);
Angle<Degree,float> z = d + Angle<Degree,float>(15.);
printf("%.2f\n",z.getVal());
return 0;
}
最佳答案
您不需要用相同的代码编写两个类,可以使用一个类模板,让编译器为您“编写”代码。
像这样的东西:
template<typename Unit>
struct Angle
{
// Member functions ...
float magnitude;
};
struct Deg;
struct Rad;
using RadAngle = Angle<Rad>;
using DegAngle = Angle<Deg>;
RadAngle toRadians(const DegAngle& inDegrees)
{
// ...
}
DegAngle toDegrees(const RadAngle& inRadians)
{
// ...
}