当前位置: 首页 > news >正文

8.原型模式(Prototype)

动机

在软件系统中,经常面临着某些结构复杂的对象的创建工作;由于需求的变化,这些对象经常面临着剧烈的变化,但是它们却拥有比较稳定一致的接口。

之前的工厂方法和抽象工厂将抽象基类和具体的实现分开。原型模式也差不多,但是原型模式将抽象基类合并。

原型模式的应用场景

原型模式特别适用于以下场景:

  • 对象的创建过程比较复杂或耗时。
  • 需要动态创建对象,且对象的类型在运行时才能确定。
  • 需要避免重复初始化对象的开销。
#include <iostream>
#include <memory>
#include <string>// 抽象类
class ISplitter {
public:virtual void split() = 0;virtual std::unique_ptr<ISplitter> clone() const = 0; // 返回一个智能指针virtual ~ISplitter() {}
};// 二进制拆分器
class BinarySplitter : public ISplitter {
private:std::string data; // 假设这是需要拆分的二进制数据
public:BinarySplitter(const std::string& data) : data(data) {}void split() override {std::cout << "Splitting binary data: " << data << std::endl;// 具体的二进制拆分逻辑}std::unique_ptr<ISplitter> clone() const override {return std::make_unique<BinarySplitter>(*this); // 深拷贝}
};// 文本拆分器
class TxtSplitter : public ISplitter {
private:std::string data; // 假设这是需要拆分的文本数据
public:TxtSplitter(const std::string& data) : data(data) {}void split() override {std::cout << "Splitting text data: " << data << std::endl;// 具体的文本拆分逻辑}std::unique_ptr<ISplitter> clone() const override {return std::make_unique<TxtSplitter>(*this); // 深拷贝}
};// 使用示例
int main() {// 创建原始对象BinarySplitter binarySplitter("01010101");TxtSplitter txtSplitter("Hello, World!");// 克隆对象std::unique_ptr<ISplitter> binaryClone = binarySplitter.clone();std::unique_ptr<ISplitter> txtClone = txtSplitter.clone();// 使用克隆对象binaryClone->split();txtClone->split();return 0;
}

模式定义

使用原型实例指定创建对象的种类,然后通过拷贝这些原型来创建新的对象。

什么时候使用原型,什么时候使用工厂最大的区分点就在于:用工厂方法创建对象是不是非常简单的几个步骤就可以把这个对象创建出来,还是说需要考虑对象很复杂的中间状态,然后又很希望保留这个中间状态,如果是后者的话就用原型。

要点总结

Prototype模式同样用于隔离类对象的使用者和具体类型(易变类)之间的耦合关系,它同样要求这些“易变类”拥有稳定的接口。

Prototype模式对于“如何创建易变类”的实体对象“采用”原型克隆的方法来做,它使得我们可以非常灵活地动态创建“拥有某些稳定接口”的新对象–所需工作仅仅是注册一个新类的对象(即原型),然后在任何需要的地方Clone。

Prototype模式中的Clone方法可以利用某些框架中的序列化来实现深拷贝。

http://www.lryc.cn/news/530724.html

相关文章:

  • Python-基于PyQt5,pdf2docx,pathlib的PDF转Word工具(专业版)
  • 13 尺寸结构模块(size.rs)
  • STM32单片机学习记录(2.2)
  • CSS 样式化表格:从基础到高级技巧
  • 【python】tkinter实现音乐播放器(源码+音频文件)【独一无二】
  • javascript常用函数大全
  • C#属性和字段(访问修饰符)
  • DeepSeek为什么超越了OpenAI?从“存在主义之问”看AI的觉醒
  • langchain基础(二)
  • 数据库安全管理中的权限控制:保护数据资产的关键措施
  • Leetcode598:区间加法 II
  • 【Proteus】NE555纯硬件实现LED呼吸灯效果,附源文件,效果展示
  • SAP HCM insufficient authorization, no.skipped personnel 总结归纳
  • 五. Redis 配置内容(详细配置说明)
  • 4 [危机13小时追踪一场GitHub投毒事件]
  • Shadow DOM举例
  • 力扣动态规划-18【算法学习day.112】
  • 网络基础
  • 使用 EXISTS 解决 SQL 中 IN 查询数量过多的问题
  • 使用SpringBoot发送邮件|解决了部署时连接超时的bug|网易163|2025
  • Ruby Dir 类和方法详解
  • 克隆OpenAI(基于openai API和streamlit)
  • 位运算算法题
  • 12 向量结构模块(vector.rs)
  • Android车机DIY开发之学习篇(六)编译讯为3568开发板安卓
  • Codeforces Round 863 (Div. 3) E. Living Sequence
  • 一文讲解HashMap线程安全相关问题(上)
  • MFC 创建Ribbon样式窗口
  • uv 安装包
  • IELTS口语练习题库