哪个类应该负责序列化

Which class should be responsible for serialization?

本文关键字:序列化      更新时间:2023-10-16

我有一个非常普遍的问题,关于什么是更好的方法,为什么:让一个对象负责序列化自身,或者有一个单独的ReaderWriter类来做到这一点?


这是一个插图。我有一个文件格式,它由一个标题和一系列对象组成。

示例 #1 - 嵌入式序列化

class Header
{
    friend std::ostream& operator<< (std::ostream& out, const Header& header);
    friend std::istream& operator>> (std::istream& in, Header& header);
}
class Object
{
    friend std::ostream& operator<< (std::ostream& out, const Object& object);
    friend std::istream& operator>> (std::istream& in, Object& object);
}
class Reader
{
    void readHeader(Header& header) { ifs_ << header; }
    void readObject(Object& object) { ifs_ << object; }
private:
    ifstream ifs_;
}
class Writer
{
    void writeHeader(Header const& header) { header >> ofs_ }
    void writeObject(Object const& object) { object >> ofs_ }
private:
    ofstream ofs_;
}

在这种情况下,所有序列化详细信息都将进入重载的<<>>运算符。

示例 #2 - 外部序列化

class Header
{
}
class Object
{
}
class Reader
{
    void readHeader(Header& header) { // serialization details go here }
    void readObject(Object& object) { // serialization details go here }
private:
    ifstream ifs_;
}
class Writer
{
    void writeHeader(Header const& header) { // serialization details go here }
    void writeObject(Object const& object) { // serialization details go here }
private:
    ofstream ofs_;
}

注意:我提供<<>>运算符只是作为示例,这并不意味着我一定想将数据存储为文本。此方法也可以替换为使用二进制格式的serialize/deserialize方法。

简短回答:恕我直言,针对每个实体类的 Reader 类专用化将是一个更好的解决方案。

长答案:

可能序列化不应该

是你的实体(即:标头)的问题,因此这个功能不应该属于它们(参见维基百科中的单一责任原则)。

另一方面,了解实体类的所有信息的外部序列化程序是系统中不允许的紧密耦合(可读性和可维护性将来会受到严重影响)。

因此,我的建议是创建读者/编写器泛化,这些泛化只知道如何序列化/反序列化特定的实体类(即:HeaderReader/HeaderWriter)。

[]的,