全部。我对 C++ 很陌生,我正在用 C++ 编写一个小型库(主要用于我自己的项目)。在设计类型层次结构的过程中,我遇到了定义赋值运算符的问题。
我采用了本文最终达到的基本方法,即对于MyClass
从一个类派生的层次结构中的每个类,Base
您定义两个赋值运算符,如下所示:
class MyClass: public Base {
public:
MyClass& operator =(MyClass const& rhs);
virtual MyClass& operator =(Base const& rhs);
};
// automatically gets defined, so we make it call the virtual function below
MyClass& MyClass::operator =(MyClass const& rhs);
{
return (*this = static_cast<Base const&>(rhs));
}
MyClass& MyClass::operator =(Base const& rhs);
{
assert(typeid(rhs) == typeid(*this)); // assigning to different types is a logical error
MyClass const& casted_rhs = dynamic_cast<MyClass const&>(rhs);
try {
// allocate new variables
Base::operator =(rhs);
} catch(...) {
// delete the allocated variables
throw;
}
// assign to member variables
}
我关心的部分是类型相等的断言。由于我正在编写一个库,其中断言可能会从最终结果中编译出来,这导致我采用了一个看起来更像这样的方案:
class MyClass: public Base {
public:
operator =(MyClass const& rhs); // etc
virtual inline MyClass& operator =(Base const& rhs)
{
assert(typeid(rhs) == typeid(*this));
return this->set(static_cast<Base const&>(rhs));
}
private:
MyClass& set(Base const& rhs); // same basic thing
};
但我一直想知道是否可以在编译时检查类型。我查看了 Boost.TypeTraits,我通过 接近了BOOST_MPL_ASSERT((boost::is_same<BOOST_TYPEOF(*this), BOOST_TYPEOF(rhs)>));
,但由于 rhs 被声明为对父类而不是派生类的引用,所以它窒息了。
现在我想起来了,我的推理似乎很愚蠢——我希望由于函数是内联的,它能够自己检查实际参数,但当然预处理器总是在编译器之前运行。但我想知道是否有人知道我可以在编译时强制执行这种检查的任何其他方式。