《原型模式(极简c++)》

本文章属于专栏《设计模式(极简c++版)》


继续上一篇《单例模式(极简c++)》。本章简要说明原型模式。本文分为**++模式说明、本质思想、实践建议、代码示例++**四个部分。

模式说明:

  • 方案:基类有一个虚函数clone,返回基类指针,派生类继承接口。这样可以直接用基类指针拷贝,且不会出现派生类数据丢失的问题
  • 优点:能对指向派生类的基类指针进行正确的拷贝
  • 缺点:每个派生类和基类都需要实现clone方法。对引用的三方库,或者被其他开发者引用是,使用成本高

本质思想:通过基类虚函数,规范指向派生类的基类的拷贝行为

实践建议:实践中基本不用。难以维护,且只能在小范围使用,另外指向派生类的基类的深拷贝效率低,所以使用频率极低。如果实在需要,在基类中维护一个基础类型,转换时,通过基础类型判断,转换成派生类再拷贝

原型模式代码示例:

cpp 复制代码
#include <iostream>
#include <string>

// 基类:鸟
class Bird {
public:
    virtual Bird* clone() const = 0;
    virtual void fly() const = 0;
};

// 派生类:麻雀
class Sparrow : public Bird {
public:
    Bird* clone() const override {
        return new Sparrow(*this); // 深拷贝
    }

    void fly() const override {
        std::cout << "Sparrow flying!" << std::endl;
    }
};

int main() {
    // 创建原型对象
    Bird* bird = new Sparrow();

    // 根据原型对象克隆新对象
    Bird* newBrid = bird->clone();

    // 测试新对象
    newBrid->fly(); // 输出: Sparrow flying!

    // 释放资源
    delete bird;
    delete newBrid;

    return 0;
}

下一篇:《适配器模式(极简c++)》

相关推荐
Dream it possible!18 分钟前
LeetCode 面试经典 150_二叉树_二叉树展开为链表(74_114_C++_中等)
c++·leetcode·链表·面试·二叉树
yi碗汤园28 分钟前
【一文了解】C#反射
开发语言·unity·c#
小羊失眠啦.1 小时前
用 Rust 实现高性能并发下载器:从原理到实战
开发语言·后端·rust
避避风港1 小时前
Java 抽象类
java·开发语言·python
cookies_s_s1 小时前
C++20 协程
linux·开发语言·c++
石油人单挑所有1 小时前
C语言知识体系梳理-第一篇
c语言·开发语言
hetao17338372 小时前
2025-11-13~14 hetao1733837的刷题记录
c++·算法
把csdn当日记本的菜鸡2 小时前
js查缺补漏
开发语言·javascript·ecmascript
hansang_IR2 小时前
【题解】洛谷 P2476 [SCOI2008] 着色方案 [记搜]
c++·算法·记忆化搜索
lkbhua莱克瓦242 小时前
Java练习——数组练习
java·开发语言·笔记·github·学习方法