深入解析工厂模式及其C#实现

工厂模式(Factory Pattern)是设计模式中的一种创建型模式,它通过工厂方法来创建对象,而不是让客户端代码直接实例化对象。这样可以避免客户端与具体类的紧密耦合,从而提高代码的灵活性、可维护性和扩展性。工厂模式能够将对象的创建过程封装起来,使得系统可以在不修改客户端代码的情况下增加新的产品。

工厂模式主要分为以下几种类型:

  1. 简单工厂模式(Simple Factory Pattern)
  2. 工厂方法模式(Factory Method Pattern)
  3. 抽象工厂模式(Abstract Factory Pattern)

本文将深入探讨这些模式,并通过C#示例代码进行说明。


1. 简单工厂模式(Simple Factory Pattern)

简单工厂模式是一种最简单的工厂模式,它通过一个工厂类来根据传入的条件创建不同的产品对象。客户端不需要直接创建对象,而是通过工厂类获取所需的产品对象。

优点:
  • 客户端代码不需要关心产品的具体实现,只需要通过工厂类来创建对象。
  • 集中管理产品的创建过程,便于修改和维护。
缺点:
  • 工厂类随着产品种类的增多会变得庞大,不易维护。
  • 每当新增产品时,需要修改工厂类,违反了开闭原则。
C# 示例代码:
// 产品接口
public interface IProduct
{void Use();
}// 具体产品A
public class ProductA : IProduct
{public void Use(){Console.WriteLine("使用产品A");}
}// 具体产品B
public class ProductB : IProduct
{public void Use(){Console.WriteLine("使用产品B");}
}// 简单工厂类
public class ProductFactory
{public static IProduct CreateProduct(string type){if (type == "A"){return new ProductA();}else if (type == "B"){return new ProductB();}else{throw new ArgumentException("未知的产品类型");}}
}// 客户端代码
public class Client
{public static void Main(string[] args){IProduct productA = ProductFactory.CreateProduct("A");productA.Use();IProduct productB = ProductFactory.CreateProduct("B");productB.Use();}
}

在这个示例中,ProductFactory 类根据传入的参数来创建不同的 IProduct 实例。客户端通过工厂类来获取产品对象,而不需要关心具体的实现类。


2. 工厂方法模式(Factory Method Pattern)

工厂方法模式是对简单工厂模式的改进,它通过定义一个工厂接口,让子类决定创建哪个具体产品。每个具体工厂负责创建一个特定的产品对象,避免了简单工厂中工厂类做大量条件判断的情况。

优点:
  • 每个工厂类只负责创建一个产品,符合单一职责原则。
  • 可以通过新增工厂类来扩展新的产品,符合开闭原则。
缺点:
  • 每增加一种产品类型,都需要增加一个工厂类,导致类的数量增多,系统复杂度上升。
C# 示例代码:
// 产品接口
public interface IProduct
{void Use();
}// 具体产品A
public class ProductA : IProduct
{public void Use(){Console.WriteLine("使用产品A");}
}// 具体产品B
public class ProductB : IProduct
{public void Use(){Console.WriteLine("使用产品B");}
}// 抽象工厂接口
public interface IFactory
{IProduct CreateProduct();
}// 具体工厂A
public class FactoryA : IFactory
{public IProduct CreateProduct(){return new ProductA();}
}// 具体工厂B
public class FactoryB : IFactory
{public IProduct CreateProduct(){return new ProductB();}
}// 客户端代码
public class Client
{public static void Main(string[] args){IFactory factoryA = new FactoryA();IProduct productA = factoryA.CreateProduct();productA.Use();IFactory factoryB = new FactoryB();IProduct productB = factoryB.CreateProduct();productB.Use();}
}

在上面的示例中,FactoryAFactoryB 各自负责创建不同的产品,客户端通过不同的工厂类来获取所需的产品实例。


3. 抽象工厂模式(Abstract Factory Pattern)

抽象工厂模式是工厂方法模式的扩展,它通过提供一个抽象工厂接口来创建一系列相关的产品,而不需要指定它们的具体类。每个工厂可以创建多个产品,通常这些产品是相关或有依赖关系的。

优点:
  • 客户端通过抽象工厂创建一系列相关产品,而不需要了解产品的具体实现。
  • 可以确保产品之间的兼容性,并且便于扩展新的产品系列。
缺点:
  • 每增加一个产品系列,就需要增加一个工厂类,导致类的数量增多,系统复杂度上升。
C# 示例代码:
// 抽象产品A
public interface IProductA
{void Use();
}// 具体产品A1
public class ProductA1 : IProductA
{public void Use(){Console.WriteLine("使用产品A1");}
}// 具体产品A2
public class ProductA2 : IProductA
{public void Use(){Console.WriteLine("使用产品A2");}
}// 抽象产品B
public interface IProductB
{void Use();
}// 具体产品B1
public class ProductB1 : IProductB
{public void Use(){Console.WriteLine("使用产品B1");}
}// 具体产品B2
public class ProductB2 : IProductB
{public void Use(){Console.WriteLine("使用产品B2");}
}// 抽象工厂接口
public interface IAbstractFactory
{IProductA CreateProductA();IProductB CreateProductB();
}// 具体工厂1
public class ConcreteFactory1 : IAbstractFactory
{public IProductA CreateProductA(){return new ProductA1();}public IProductB CreateProductB(){return new ProductB1();}
}// 具体工厂2
public class ConcreteFactory2 : IAbstractFactory
{public IProductA CreateProductA(){return new ProductA2();}public IProductB CreateProductB(){return new ProductB2();}
}// 客户端代码
public class Client
{public static void Main(string[] args){IAbstractFactory factory1 = new ConcreteFactory1();IProductA productA1 = factory1.CreateProductA();IProductB productB1 = factory1.CreateProductB();productA1.Use();productB1.Use();IAbstractFactory factory2 = new ConcreteFactory2();IProductA productA2 = factory2.CreateProductA();IProductB productB2 = factory2.CreateProductB();productA2.Use();productB2.Use();}
}

在上述示例中,ConcreteFactory1ConcreteFactory2 分别创建一系列相关的产品对象。客户端可以选择不同的工厂来获取产品系列,确保产品的兼容性。


总结

  • 简单工厂模式:适用于产品种类较少的情况,通过一个工厂类来创建不同的产品。
  • 工厂方法模式:适用于产品种类较多的情况,通过具体工厂类来创建不同的产品,符合开闭原则。
  • 抽象工厂模式:适用于需要创建多个相关产品系列的情况,确保不同系列的产品兼容性。

通过工厂模式,程序的扩展性和灵活性得到了提升。选择合适的工厂模式可以帮助我们在项目中灵活、便捷地管理对象的创建过程。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/33762.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

力扣——合并K个排序链表

题目链接: 链接 题目描述: 思路: 同步合并 已知顺序排列,每个链表的node比较再加进结果,用优先队列方便比较node,可以先把每个链表的头结点加进队列,然后队列头出,出来的头还有n…

可复用表格组件设计与实现:分页、排序、筛选全功能解析

文章目录 一、组件设计思路1.1 功能需求分析1.2 技术选型 二、组件架构设计2.1 组件结构2.2 数据流设计 三、核心代码实现3.1 基础表格组件3.2 状态管理 四、功能模块实现4.1 分页组件4.2 排序控制4.3 筛选控制 五、性能优化方案5.1 虚拟滚动5.2 防抖筛选 六、完整测试方案6.1 …

Unity屏幕适配——立项时设置

项目类型:2D游戏、竖屏、URP 其他类型,部分原理类似。 1、确定设计分辨率:750*1334 为什么是它? 因为它是 iphone8 的尺寸,宽高比适中。 方便后续适配到真机的 “更长屏” 或 “更宽屏” 2、在场景…

PawSQL for TDSQL:腾讯云TDSQL数据库性能优化全攻略

TDSQL 作为腾讯云推出的分布式数据库,凭借其高扩展性、高可用性和高性能等优势,广泛应用于金融、互联网、政务等领域。随着业务的不断增长和数据量的爆炸式增长,如何优化 TDSQL 数据库的性能,成为众多企业和开发者面临的挑战。本文…

机器学习(七)

一,监督学习和无监督学习聚类的数据集比较: 监督学习: 数据集包括输入的数据和与之对应的标签 无监督学习: 数据集仅含有输入的数据,要求算法自己通过所给的数据集来确定决策边界 二,聚类(Clustering): 聚…

海鲜水产行业wordpress外贸主题

模板采用清新的海洋风格设计,完美契合水产和海鲜行业的特点,让您的网站在众多竞争者中脱颖而出。 高质量的图片展示区域,让您可以展示新鲜捕捞的海鲜产品,吸引客户的注意力。 多功能性,满足业务需求: 模…

调优案例一:堆空间扩容提升吞吐量实战记录

📝 调优案例一:堆空间扩容提升吞吐量实战记录 🔧 调优策略:堆空间扩容三部曲 # 原配置(30MB堆空间) export CATALINA_OPTS"$CATALINA_OPTS -Xms30m -Xmx30m"# 新配置(扩容至120MB&am…

【大模型系列】llama.cpp本地运行大模型

上一篇链接: 【大模型系列】使用ollama本地运行千问2.5模型 我们讲了ollama本地运行大模型,这里我们介绍另一种本地运行大模型的方法:llamacpp 软件下载 下载地址:https://github.com/ggml-org/llama.cpp/releases 下载cpu版本的llamacpp&a…

maven之自定义插件

写在前面 在使用maven肯定是离不开插件的,比如执行mvn clean或者时mvn compile其实运行的就是绑定的默认插件。虽然我们一般不需要来自定义插件,但是为了使用的过程中更加的清晰,来尝试自定义插件还是很有必要的,所以本文就一起来…

工程实践:如何使用SU17无人机来实现室内巡检任务

阿木实验室最近发布了科研开发者版本的无人机SU17,该无人机上集成了四目视觉,三维激光雷达,云台吊舱,高算力的机载计算机,是一个非常合适的平台用于室内外巡检场景。同时阿木实验室维护了多个和无人机相关的开源项目。…

【瞎折腾/Dify】使用docker离线部署Dify

文章目录 说在前面安装Docker(外网)获取Dify源码(外网)拉取docker镜像(外网)导出镜像(内网)导入镜像(内网)运行问题 说在前面 外网操作系统:windows内网操作系统:ubuntu外网docker desktop版本:4.29.0外网docker版本:version 26.0…

【Git】配置Git

配置Git 忽略特殊文件 在日常开发中,有些文件不想或不应该提交到远端,如保存数据库密码的配置文件。 在Git工作区的根目录下创建一个特殊的.gitignore文件,把要忽略的文件名填进去,Git就会自动忽略这些文件。 不需要从头写.gi…

mysql学习-常用sql语句

1、安装mysql参考网上链接,进入mysql数据库 mysql -u root -p 2、数据库操作 2.1、创建数据库 create database 数据库名 default character set utf8; 2.2、显示所有数据库 show databases; 2.3、选择数据库 use elementInfo; 2.4、删除数据库 drop database…

PostgreSQL16 的双向逻辑复制

一、配置 双向逻辑复制具体步骤 参考:PostgreSQL 16 双向逻辑复制与事务回环控制 - 墨天轮 1. 安装和准备环境 确保在所有参与复制的服务器上都安装了 PostgreSQL 16。主服务器:192.168.0.100从服务器:192.168.0.102 2. 配置 PostgreSQL 在每个服务…

FastAPI复杂查询终极指南:告别if-else的现代化过滤架构

title: FastAPI复杂查询终极指南:告别if-else的现代化过滤架构 date: 2025/3/14 updated: 2025/3/14 author: cmdragon excerpt: 本文系统讲解FastAPI中复杂查询条件的构建方法,涵盖参数验证、动态过滤、安全防护等18个核心技术点。通过引入策略模式、声明式编程等技术,彻…

C++前缀和

个人主页:[PingdiGuo_guo] 收录专栏:[C干货专栏] 大家好,今天我们来了解一下C的一个重要概念:前缀和 目录 1.什么是前缀和 2.前缀和的用法 1.前缀和的定义 2.预处理前缀和数组 3.查询区间和 4.数组中某个区间的和是否为特定…

机器学习基础

目录 泛化误差 偏差和方差 噪声 生成模型和判别模型 正态分布(Normal Distribution) 超参数选择 Grid Search 网格搜索 Random Search 随机搜索 Hyperopt Hyperas 参数估计方法对比 MLE 最大似然估计 MAP最大后验估计 贝叶斯估计 距…

中山六院团队发表可解释多模态融合模型Brim,可以在缺少分子数据时借助病理图像模拟生成伪基因组特征|顶刊解读·25-02-14

小罗碎碎念 在癌症诊疗领域,精准预测患者预后对临床决策意义重大。传统的癌症分期系统,如TNM分期,因无法充分考量肿瘤异质性,难以准确预测患者的临床结局。而基于人工智能的多模态融合模型虽有潜力,但在实际临床应用中…

系统可观测性(5)OpenTelemetry基础使用

系统可观测性(5)OpenTelemetry基础概念 Author: Once Day Date: 2025年3月12日 一位热衷于Linux学习和开发的菜鸟,试图谱写一场冒险之旅,也许终点只是一场白日梦… 漫漫长路,有人对你微笑过嘛… 本文档翻译整理自《OpenTelemetry Docs》&a…

OpenHarmony自定义子系统、部件与模块

如图所示,OpenHarmony系统源码中,大体上按照不同种类的功能分成多个子系统,然后一个子系统内部进一步在同类功能上的差异性划分成一个或多个部件,也就是说一个部件表示一个具体功能的源码集合。最后一个部件的源码再划分成一个或多…