设计模式01:创建型设计模式之单例、简单工厂的使用情景及其基础Demo

devtools/2024/12/28 2:02:37/

一、单例模式

1.情景

连接字符串管理

2.好处

  • 代码简洁:可全局访问连接字符串。
  • 性能优化:一个程序一个连接实例,避免反复创建对象(连接)和销毁对象(连接)。
  • 线程安全:连接对象不会被重复创建,从而避免并发冲突。

3.Demo

using System;
using SqlSugar;public class SqlSugarSingleton
{// 使用 Lazy<T> 来保证延迟初始化和线程安全//Lazy<T> 通过内部的机制确保在多线程环境下的安全性,而且在首次访问时才会初始化对象实例,从而避免了重复创建和资源浪费。private static readonly Lazy<SqlSugarClient> lazyInstance = new Lazy<SqlSugarClient>(() =>{// 配置 SqlSugarClient 实例return new SqlSugarClient(new ConnectionConfig{ConnectionString = "Server=localhost;Database=TestDB;User Id=myuser;Password=mypassword;",DbType = DbType.MySql, // 根据你的数据库类型选择IsAutoCloseConnection = true,InitKeyType = InitKeyType.Attribute});});// 获取 SqlSugarClient 实例public static SqlSugarClient Instance => lazyInstance.Value;
}class Program
{static void Main(){// 获取唯一的 SqlSugarClient 实例SqlSugarClient db = SqlSugarSingleton.Instance;// 示例查询var result = db.Queryable<Student>().Where(s => s.Age > 18).ToList();Console.WriteLine($"查询结果数量: {result.Count}");}
}// 假设我们有一个学生类,用于展示查询操作
public class Student
{public int Id { get; set; }public string Name { get; set; }public int Age { get; set; }
}

二、简单工厂模式

1.情景 

        可由参数决定实例化哪个类,不同的类调用相同的方法有不同的效果。

2.好处

  • 便于开发:无需知道具体类的实现细节,只需要通过入参实现想要的效果
  • 扩展方便:若要增加或者修改,对抽象类的子类操作即可,不需要改客户端代码(Main函数)
  • 简单简洁:减少了客户端(Main函数)的复杂度,调用时简洁大方。

3.代码思路

  • 抽象类和子类:写一个抽象类(含抽象方法),再写n个它的子类(及其父类抽象方法的实现)
  • 工厂类:写一个简单工厂,由字符串决定要实例化的类
  • 客户端使用:先用简单工厂创建对象,然后再用这个对象调用方法

4.Demo

using System;// 抽象产品类 (先写一个抽象类,含有抽象方法)
public abstract class Product
{public abstract void Show();
}// 具体产品 A (再写n个它的子类,及其父类抽象方法的实现)
public class ConcreteProductA : Product
{public override void Show(){Console.WriteLine("ConcreteProductA");}
}// 具体产品 B
public class ConcreteProductB : Product
{public override void Show(){Console.WriteLine("ConcreteProductB");}
}// 简单工厂 (然后,写一个简单工厂,由字符串决定要实例化的类)
public class ProductFactory
{public static Product CreateProduct(string type){if (type == "A")return new ConcreteProductA();else if (type == "B")return new ConcreteProductB();elsethrow new ArgumentException("Invalid product type");}
}class Program
{static void Main(){//客户端使用:先用简单工厂创建对象,然后再用这个对象调用方法Product productA = ProductFactory.CreateProduct("A");productA.Show();Product productB = ProductFactory.CreateProduct("B");productB.Show();}
}


http://www.ppmy.cn/devtools/145986.html

相关文章

【设计模式】装饰器模式(Decorator Pattern)

定义 装饰器模式&#xff08;Decorator Pattern&#xff09;是一种结构型设计模式。 装饰器模式通过创建一个装饰类&#xff0c;包装原始对象&#xff0c;并在保持原始对象接口不变的情况下&#xff0c;扩展其功能。 模式示例 #include <iostream> #include <strin…

详细对比JS中XMLHttpRequest和fetch的使用

在JavaScript中&#xff0c;XMLHttpRequest 和 fetch 是两种用于进行 HTTP 请求的 API。它们的主要区别在于设计理念、用法和功能支持。以下是两者的详细对比&#xff1a; 1. 语法与用法 XMLHttpRequest: 较老的 API&#xff0c;最早出现在 2000 年代。支持异步和同步请求&…

【开发问题记录】eslint9 中 eslint 和 prettier冲突

文章目录 1、引言2、问题复现3、问题修复4、注意5、eslint-plugin-prettier/recommended 与自己的默认规则&#xff0c;冲突解决 1、引言 eslint 和 prettier 这俩都是在前端工程化中不可缺少的东西&#xff0c;但这俩&#xff0c;在一块运行的时候&#xff0c;总会有点问题 Es…

TP5 动态渲染多个Layui表格并批量打印所有表格

记录&#xff1a; TP5 动态渲染多个Layui表格每个表格设置有2行表头&#xff0c;并且第一行表头在页面完成后动态渲染显示内容每个表格下面显示统计信息可点击字段排序一次打印页面上的所有表格打印页面上多个table时,让每个table单独一页 后端代码示例&#xff1a; /*** Nod…

每天40分玩转Django:Django表单集

Django表单集 一、今日学习内容概述 学习模块重要程度主要内容表单集基础⭐⭐⭐⭐⭐表单集定义、基本用法内联表单集⭐⭐⭐⭐⭐内联表单、关联数据表单集验证⭐⭐⭐⭐自定义验证、错误处理动态表单集⭐⭐⭐⭐动态添加删除表单 二、基本模型定义 # models.py from django.db…

21天掌握JavaWeb - 第17天:前端页面开发与集成测试

目标 在本章节中&#xff0c;我们将学习如何根据后端API编写前端页面&#xff0c;并进行集成测试以确保前后端功能正常。 前端页面开发 核心概念 前端页面开发通常涉及HTML、CSS和JavaScript的使用&#xff0c;以构建用户界面和交互逻辑。 优势 用户体验&#xff1a;良好…

渗透测试发现漏洞产生原因以及解决方法|网络安全|渗透测试服务

渗透测试发现的问题 SQL注入攻击 原因 后端数据库过于信任前端传入数据 攻击方式&#xff1a; 通过前端输入相关SQL语句&#xff0c;使得后端数据库执行&#xff0c;套取数据库中的关键信息 解决方法&#xff1a; 对于前端传来的数据不直接进行操作数据库&#xff0c;而…

最长公共子序列【东北大学oj数据结构10-3】C++

题面 对于给定两个序列 X 和 Y , 序列 Z 是 X 和 Y 的公共子序列是指如果 Z 同时是 X 和 Y 的子序列。 例如&#xff1a;如果 X {a, b, c, b, d, a, b} 和 Y {b, d, c, a, b, a} , 那么序列 {b, c, a} 是 X 和 Y 的一个公共子序列。 但是序列 { b , c, a } 不是 X 和 Y 的最…