首页 > 后端开发 > C++ > 如何使用工厂模式在 C 中优雅地将类序列化为流?

如何使用工厂模式在 C 中优雅地将类序列化为流?

Linda Hamilton
发布: 2024-10-29 02:45:29
原创
980 人浏览过

How to Elegantly Serialize Classes to a Stream in C   Using the Factory Pattern?

揭秘类的序列化到流

当面对 C 中的对象序列化需求时,许多人采用一种熟悉的模式,涉及基于类 ID 的切换:

<code class="cpp">class Serializable {
  public:
    static Serializable *deserialize(istream &amp;is) {
        int id;
        is >> id;
        switch(id) {
          case EXAMPLE_ID:
            return new ExampleClass(is);
          //...
        }
    }

    void serialize(ostream &amp;os) {
        os << getClassID();
        serializeMe(os);
    }

  protected:
    int getClassID()=0;
    void serializeMe(ostream &amp;os)=0;
};
登录后复制

虽然这种方法看起来很直观,但它存在潜在的陷阱:

工厂模式方法

一种更优雅和可扩展的方法解决方案是采用工厂模式。工厂类不依赖类 ID,而是根据一组已注册的键函数对创建对象。这些函数返回相应类的实例。

<code class="cpp">template<typename K, typename T>
class Factory {
    typedef T *(*CreateObjectFunc)();
    std::map<K, CreateObjectFunc> mObjectCreator;

    template<typename S> 
    static T* createObject(){ 
        return new S(); 
    }

    template<typename S> 
    void registerClass(K id){ 
        mObjectCreator.insert( std::make_pair<K,CreateObjectFunc>(id, &createObject<S> ) ); 
    }

    T* createObject(K id){
        typename std::map<K, CreateObjectFunc>::iterator iter = mObjectCreator.find(id); 
        if (iter == mObjectCreator.end()){ 
            return NULL;
        }
        return ((*iter).second)();
    }
};</code>
登录后复制

在此实现中,每个感兴趣的类都向工厂注册,将其类 ID 与创建函数相关联。当要反序列化对象时,会在工厂中查询相应的类 ID。如果找到,则调用创建函数来实例化该对象。

以上是如何使用工厂模式在 C 中优雅地将类序列化为流?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板