我正在尝试使用boost::serialization
序列化一个类,但是当派生类声明为final
时它会失败。
#include <fstream>
#include <boost/serialization/access.hpp>
#include <boost/serialization/base_object.hpp>
#include <boost/archive/binary_oarchive.hpp>
class Base {
public:
virtual ~Base() = default;
virtual void Foo() = 0;
private:
friend class boost::serialization::access;
template <typename Archive>
void serialize(Archive& archive, const unsigned int version) {}
};
class Derived final: public Base {
public:
void Foo() override {}
private:
friend class boost::serialization::access;
template <typename Archive>
void serialize(Archive& archive, const unsigned int version) {
archive & boost::serialization::base_object<Base>(*this);
}
};
int main() {
Derived foo;
std::ofstream output("output");
boost::archive::binary_oarchive archive(output);
archive << foo;
}
error: cannot derive from ‘final’ base ‘Derived’ in derived type ‘boost::detail::is_virtual_base_of_impl<Base, Derived, mpl_::bool_<true> >::boost_type_traits_internal_struct_X’
struct boost_type_traits_internal_struct_X : public Derived, virtual Base
如果省略final
指定者,则没有错误。这个错误的原因是什么可以避免?
答案 0 :(得分:2)
原因是is_virtual_base_of
是Boost的一个实现细节,它试图从它的参数派生出来(通过比较大小)来确定一个类是否是另一个类的虚拟基础。
在编写本文时,没有final
个类,因此未考虑此案例。您可能想在Boost邮件列表上询问是否有人可以增强/修复它,这可能是也可能是不可能的。传统上,Boost尽力检测类型特征,但可以做的事情是有限的。大多数编译器都有内置的方法来确定某些类型属性,因为没有办法只用C ++代码检测它们。