首页 > 其他分享 >设计模式 - 原型模式

设计模式 - 原型模式

时间:2025-01-03 16:14:45浏览次数:1  
标签:创建 模式 Content IDocument 原型 Print 设计模式 public

概述

原型模式(Prototype Pattern)是一种创建型设计模式,它通过复制现有的实例来创建新的对象,而不是通过实例化类。原型模式允许一个对象在创建新的对象时,通过复制自身来实现。这种模式特别适用于创建复杂对象的场景,因为它可以避免重复初始化对象的开销。

结构

原型模式包含以下几个角色:

  1. 原型(Prototype):定义一个用于复制自身的接口。
  2. 具体原型(ConcretePrototype):实现原型接口,能够复制自身的具体类。
  3. 客户端(Client):通过调用原型对象的复制方法来创建新的对象。

示例代码

假设我们有一个应用程序需要创建不同类型的文档(如Word文档和PDF文档)。
代码地址

原型接口

public interface IDocument
{
    IDocument Clone();
    void Print();
}

具体原型

public class WordDocument : IDocument
{
    public string Content { get; set; }

    public IDocument Clone()
    {
        return (IDocument)this.MemberwiseClone();
    }

    public void Print()
    {
        Console.WriteLine($"Word Document Content: {Content}");
    }
}

public class PdfDocument : IDocument
{
    public string Content { get; set; }

    public IDocument Clone()
    {
        return (IDocument)this.MemberwiseClone();
    }

    public void Print()
    {
        Console.WriteLine($"PDF Document Content: {Content}");
    }
}

客户端代码

class Program
{
    static void Main(string[] args)
    {
        // 创建原型文档
        WordDocument wordDoc = new WordDocument { Content = "This is a Word document." };
        PdfDocument pdfDoc = new PdfDocument { Content = "This is a PDF document." };

        // 通过克隆创建新文档
        IDocument clonedWordDoc = wordDoc.Clone();
        IDocument clonedPdfDoc = pdfDoc.Clone();

        // 打印原型文档和克隆文档
        wordDoc.Print();
        clonedWordDoc.Print();
        pdfDoc.Print();
        clonedPdfDoc.Print();
    }
}

应用场景

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

  1. 当一个系统应该独立于它的产品创建、构成和表示时。
  2. 当要实例化的类是在运行时刻指定时,例如,通过动态装载。
  3. 为了避免创建一个与产品类层次平行的工厂类层次时。
  4. 当一个类的实例只能有几个不同状态组合中的一种时。建立相应数目的原型并克隆它们可能比每次用合适的状态手工实例化该类更方便一些。

优缺点

优点

  • 减少初始化开销:通过复制现有的实例来创建新的对象,避免了重复初始化对象的开销。
  • 简化对象创建:可以很容易地创建复杂对象的副本,而不需要知道具体的创建过程。

缺点

  • 深拷贝和浅拷贝问题:在实现克隆方法时,需要注意对象的深拷贝和浅拷贝问题,可能会导致一些意想不到的副作用。
  • 实现复杂性:对于包含复杂引用关系的对象,克隆方法的实现可能会比较复杂。

标签:创建,模式,Content,IDocument,原型,Print,设计模式,public
From: https://www.cnblogs.com/Tangtang1997/p/18650305

相关文章

  • 设计模式 - 装饰模式
    概述装饰模式(DecoratorPattern)是一种结构型设计模式,它允许向一个现有的对象添加新的功能,同时又不改变其结构。装饰模式通过创建一个装饰类来包装原始类,从而在保持类方法签名完整的前提下,提供了额外的功能。装饰模式比生成子类更灵活,能够动态地扩展对象的功能。结构装饰模式包......
  • 设计模式 - 组合模式
    概述组合模式(CompositePattern)是一种结构型设计模式,它将对象组合成树形结构以表示“部分-整体”的层次结构。组合模式使得客户可以统一地处理单个对象和组合对象。通过使用组合模式,客户代码可以一致地处理简单和复杂的元素,从而提高系统的灵活性和可扩展性。结构组合模式包含以......
  • 设计模式 - 桥接模式
    概述桥接模式(BridgePattern)是一种结构型设计模式,它通过将抽象部分与实现部分分离,使它们可以独立变化。桥接模式的核心思想是将抽象和实现解耦,使得它们可以独立地变化,从而提高系统的灵活性和可扩展性。结构桥接模式包含以下几个角色:抽象(Abstraction):定义抽象类,并包含一个对实......
  • 设计模式 - 代理模式
    概述代理模式(ProxyPattern)是一种结构型设计模式,它为其他对象提供一种代理以控制对这个对象的访问。代理模式通过引入一个代理对象来控制对原对象的访问,可以在不改变原对象的情况下扩展其功能。代理模式常用于延迟加载、访问控制、日志记录等场景。结构代理模式包含以下几个角......
  • 设计模式 - 享元模式
    概述享元模式(FlyweightPattern)是一种结构型设计模式,它通过共享大量细粒度对象来减少内存使用和提高性能。享元模式的核心思想是将对象的状态分为内部状态和外部状态,内部状态是可以共享的,而外部状态是可以变化的。通过共享内部状态,享元模式可以显著减少内存消耗。结构享元模式......
  • 设计模式 - 外观模式
    概述外观模式(FacadePattern)是一种结构型设计模式,它为子系统中的一组接口提供一个一致的界面,使得子系统更容易使用。外观模式通过引入一个外观类,简化了复杂子系统的接口,减少了客户端与子系统之间的耦合,从而提高了系统的易用性和可维护性。结构外观模式包含以下几个角色:外观(Fa......
  • 设计模式 - 解释器模式
    概述解释器模式(InterpreterPattern)是一种行为型设计模式,它为某种语言定义其文法表示,并提供一个解释器来解释语言中的句子。解释器模式通过定义一个解释器类来解释语言中的句子,使得语言的文法和解释逻辑可以独立于具体的应用程序。解释器模式常用于开发编译器、脚本语言解析器等......
  • 设计模式 - 命令模式
    概述命令模式(CommandPattern)是一种行为型设计模式,它将请求封装成对象,从而使你可以用不同的请求对客户进行参数化。命令模式允许请求的发送者与接收者解耦,使得请求的发送者不需要知道请求的接收者是谁,也不需要知道如何处理请求。命令模式还支持请求的排队、记录日志以及撤销操作......
  • 设计模式 - 责任链模式
    概述责任链模式(ChainofResponsibilityPattern)是一种行为型设计模式,它通过将请求沿着处理者链传递,直到有一个处理者处理它为止。责任链模式使得多个对象都有机会处理请求,从而避免了请求的发送者和接收者之间的耦合。通过将请求的处理者连成一条链,责任链模式可以动态地指定处理......
  • 【安全就业】信息安全团队的角色分工与协作模式详解
    一、信息安全团队——数字世界的“守护者联盟”信息如空气般渗透到生活的每一个角落。从日常的网上购物、移动支付,到企业的核心商业机密、政府的关键决策数据,信息的安危牵动着各方的神经。不妨回顾一下热门影视作品,像《风暴舞》聚焦现代信息安全题材,主角们在都市丛林中与黑客......