设计模式——模板方法模式封装.net Core读取不同类型的文件

1、模板方法模式

模板方法模式:定义一个操作中的算法骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。

特点:通过把不变的行为搬移到超类,去除子类中重复的代码来体现它的优势。

模板方法模式提供了一个很好的代码复用平台。当不变的和可变的行为在子类实现中混合在一起的时候,不变的行为就会在子类中重复出现。我们通过模板方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变的行为的纠缠。

2、Net Core 读取的类型文件

读取不同类型文件的代码

cs 复制代码
 //读取JSON
 ConfigurationBuilder builder = new ConfigurationBuilder();
 builder.AddJsonFile("configuration.json");
 var config = builder.Build();
 var collections = config.AsEnumerable();

 //读取INI
 ConfigurationBuilder builder = new ConfigurationBuilder();
 builder.AddIniFile("configuration.ini");
 var config = builder.Build();
 var collections = config.AsEnumerable();

 //读取XML
 ConfigurationBuilder builder = new ConfigurationBuilder();
 builder.AddXmlFile("configuration.xml");
 var config = builder.Build();
 var collections = config.AsEnumerable();

如上代码:如果不使用模板方法模式,定义读取文件基类,子类中重写读取方法,如下代码

cs 复制代码
 //定义读取文件的基类
 public abstract class AFileRead
 {
     public abstract void Read(string path);
 }

 //定义读取JSON文件的子类
 public class FileReadJson:AFileRead
 {
     public override void Read(string path)
     {
         ConfigurationBuilder builder = new ConfigurationBuilder();
         builder.AddJsonFile(path);
         var config = builder.Build();
         var collections = config.AsEnumerable();
     }
 }

 //定义读取INI文件的子类
public class FileReadIni : AFileRead
{
    public override void Read(string path)
    {
        ConfigurationBuilder builder = new ConfigurationBuilder();
        builder.AddIniFile(path);
        var config = builder.Build();
        var collections = config.AsEnumerable();
    }
}
//定义读取XML文件的子类
 public class FileReadXml:AFileRead
 {
     public override void Read(string path)
     {
         ConfigurationBuilder builder = new ConfigurationBuilder();
         builder.AddXmlFile(path);
         var config = builder.Build();
         var collections = config.AsEnumerable();
     }
 }

上述代码中,只有一行读取不同类型文件代码不同,其余代码都相同。这只是单独的一个读取文件的功能,代码量很小,如果是一个特别大的功能,代码过多,那么如果要更改的话,工作量也是很大的。

为了减少重复的代码,如何去解决这个问题?

这个时候,模板方法模式,就起作用了。模板方法模式将子类中不变的行为定义到基类中,子类中只留下可变的行为,这样子类中就摆脱了重复代码的纠缠,代码如下:

cs 复制代码
//定义读取文件的接口
public interface IFileRead
{
    IEnumerable<KeyValuePair<string,string>> ReadFile();
}

//定义读取文件,封装重复代码,将可变的行为延迟到子类中实现
public abstract class AFileRead : IFileRead
{
    public IEnumerable<KeyValuePair<string, string>> ReadFile()
    {
        ConfigurationBuilder builder = new ConfigurationBuilder();
        AddFile(builder);  
        var config = builder.Build();
        var collections = config.AsEnumerable();
        return collections;
    }
    //这个函数需要延迟到子类中去实现
    protected abstract IConfigurationBuilder AddFile(ConfigurationBuilder builder);
}
//读取JSON文件
public class ReadJsonFile : AFileRead
{
    protected override IConfigurationBuilder AddFile(ConfigurationBuilder builder)
    {
        return builder.AddJsonFile("configuration.json");
    }
}
//读取XML文件
public class ReadXmlFile : AFileRead
{
    protected override IConfigurationBuilder AddFile(ConfigurationBuilder builder)
    {
        return builder.AddXmlFile("configuration.xml");
    }
}
//读取Ini文件
public class ReadIniFile : AFileRead
{
    protected override IConfigurationBuilder AddFile(ConfigurationBuilder builder)
    {
        return builder.AddIniFile("configuration.ini");
    }
}

总结: 模板方法模式,帮助我们封装了不变的行为,涉及到实现某些特定步骤时,就延迟到了子类中去实现,在更改某个读取文件的函数时,不会影响到其他读取文件的功能。

相关推荐
在西安放羊的牛油果5 小时前
我把 2000 行下单代码,重构成了一套交易前端架构
前端·设计模式·架构
寅时码1 天前
React 正在演变为一场不可逆的赛博瘟疫:AI 投毒、编译器迷信与装死的官方
前端·react.js·设计模式
willow4 天前
Axios由浅入深
设计模式·axios
七月丶6 天前
别再手动凑 PR 了:这个 AI Skill 会按仓库习惯自动建分支、拆提交、提 PR
人工智能·设计模式·程序员
刀法如飞6 天前
从程序员到架构师:6大编程范式全解析与实践对比
设计模式·系统架构·编程范式
九狼6 天前
Flutter + Riverpod +MVI 架构下的现代状态管理
设计模式
静水流深_沧海一粟7 天前
04 | 别再写几十个参数的构造函数了——建造者模式
设计模式
StarkCoder7 天前
从UIKit到SwiftUI的迁移感悟:数据驱动的革命
设计模式
阿星AI工作室7 天前
给openclaw龙虾造了间像素办公室!实时看它写代码、摸鱼、修bug、写日报,太可爱了吧!
前端·人工智能·设计模式