随笔 - 163  文章 - 2  评论 - 370  阅读 - 46万 

[导读]

[设计模式整理笔记 一] 基础知识

[设计模式整理笔记 二] 简单工厂模式(Simple Factory)

[设计模式整理笔记 三] 工厂模式(Factory)

[设计模式整理笔记 四] 抽象工厂模式(Abstract Factory)

[设计模式整理笔记 五] 创建者模式(Builder)

[设计模式整理笔记 六] 工厂模式与创建者模式总结

[设计模式整理笔记 七] 原型模式(ProtoType)

[设计模式整理笔记 八] 单例模式(Singleton)

[设计模式整理笔记 九] 外观模式(Facade)

....后续, 包括部分例子

[/导读]

 

设计模式的范围极广, 我最近也是略来整理与研究了一下, 感觉每一段时间整理一下自己学到的东西, 会发现得到的知识会比以前学的更多更全面, 不然都是散散的在脑袋里面。下面例子是一个大型企业的计算工资模式, 因为有很多各地的子公司, 当然计算工资的方法也是不同的。

先定义一个接口, 确定计算工资的方法, 如下:

复制代码
using System;

namespace ConsoleApp
{
    
public interface ISalary
    {
        
void CommandSalary();
    }
}
复制代码

 

下面各地不同的子公司分别继承这个接口的CommandSalary方法,下面是深圳与北京二个地方的计算方法。设计二个类如下:

复制代码
代码
using System;

namespace ConsoleApp
{
    
public class ShenZhenSalary : ISalary
    {
        
public void CommandSalary()
        {
            Console.WriteLine(
"这是深圳子公司的工资计算模块");
        }
    }
}
复制代码

 

 北京子公司

复制代码
代码
using System;

namespace ConsoleApp
{
    
public class BeiJinSalary : ISalary
    {
        
public void CommandSalary()
        {
            Console.WriteLine(
"这是北京子公司的工资计算模块");
        }
    }
}
复制代码

 

到里面基本类已经设计完成, 好多人都会在代码中要用到时候new一个出来,这样的代码可能会造成难以维护, 给人好乱的感觉。 或像下面的代码那样调用,代码如下:

复制代码
代码
using System;

namespace ConsoleApp
{
    
class Program
    {
        
public static void Main(string[] args)
        {
            ISalary Salary 
= CreateSalary("BeiJin");  //需要调用子公司的工资计算过程时, 把子公司的名称传进去
            Salary.CommandSalary();
            Console.ReadLine();
        }

        
/// <summary>
        
/// 通过传进的公司名返回相应的实例
        
/// </summary>
        
/// <param name="CompanyName">子公司的名称</param>
        
/// <returns></returns>
        private static ISalary CreateSalary(string CompanyName)
        {
            ISalary Salary 
= null;
            
if (CompanyName == "ShenZhen")  //这里可以通过更多方法来判断,通过不同的名返回相应的实例
            {
                Salary 
= new ShenZhenSalary();
            }
            
else if (CompanyName == "BeiJin")
            {
                Salary 
= new BeiJinSalary();
            }
            
return Salary;
        }
    }
}
复制代码

 

这样就可以调用计算得到各子公司的工资, 对于小型的公司, 这样的设计已经是相当的完美了, 但对于一个大公司, 子公司可能有几十个更甚至几百个, 这样在CreateSalary中就需要更多的if来判断了, 这显然对维护是极为不好的, 那需要怎样设计呢? 这就是所要讨论到的设计模式了, 下面接着的文章就会是常用的工厂模式来编写这个模块。

注:这是一个新手常用的写法,这还没讲到工厂模式,这里只是说这样写的类不好,不符合系统的设计模式, 先举个反例, 后面将会介绍设计模式。有些朋友没看清楚, 标注一下。

 

(注:这是个人学习过程的心得,可能存在极大的错误,请大家指正)

posted on   风浪  阅读(2088)  评论(17编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示