在我最近发布的一个问题的评论中(C++: Bad Form to Call Base Class Asssignment Operator in Derived Class Constructor?)我遇到了另一个关于如何使用 static_cast 从派生类型转换为基类型的问题。可以在此处找到该问题的支持文档:Why does static_cast(*this) to a base class create a temporary copy?.
我的主要问题是我现在使用 static_cast 将其转换为派生类中的基类没有问题。但是,我无法执行从派生引用到基引用的静态转换。我只在派生类的相等运算符中这样做。这是问题:
bool Derived::operator==(const Derived& other_derived) {
// first call the operator == from the base class...
if (static_cast<Base&>(*this) == static_cast<Base&>(other_derived)) {
// continue checks for derived member variables
}
}
编译器对上面的 if 语句大喊大叫。this 的 static_cast 没有问题,但无法将派生类的 static_cast 解释为基类。如果我删除引用,这编译得很好,但是如两个引用的问题所示,这将不必要地创建一个临时对象。
结果,我想知道我是否缺少从派生类到基类的构造函数。我会在哪里编写这样的构造函数(因为它是基类型的构造函数)?我认为在基类的源代码中这样做是没有意义的,因为这不是本质上使基类自定义并破坏了可重用代码的精神吗?
一个更简单的选择是只接受在此函数中临时创建对象,但该函数最终可能会被频繁调用,因此我不确定我是否可以接受性能损失。
还有什么我应该考虑的遗漏吗?与往常一样,提前感谢您的帮助。