【设计模式】装饰器模式(定义 | 特点 | Demo入门讲解)

简介: 【设计模式】装饰器模式(定义 | 特点 | Demo入门讲解)

定义

所谓装饰器模式其实就是在原有的功能上做一个增强!!

换句话说:以前你妈妈揍你的时候用的巴掌,但是你妈妈为了增强伤害性,于是在手上拿了一根木棍,同样的力度,同样是在打你,造成的伤害不一样,木棍带来的就是增强效果!你妈妈可以在木棍和巴掌之间来回切换武器,这个木棍就是装饰器!!

比如我们以前用过一个数据访问层框架:MybatisPlus对吧?我们知道MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

而MybatisPlus只做增强不做改变!!!

装饰模式的结构

快速入门 | Demo

顶层抽象DataSource数据源接⼝

/**
 * @author linghu
 * @date 2024/7/4 17:34
 * 顶层抽象DataSource数据源接⼝
 */
public interface DataSource {
    void writeData(String data);
    String readData();
}

具体实现类

/**
 * @author linghu
 * @date 2024/7/4 17:38
 */
public class FileDataSource implements DataSource{
    private String name;
    public FileDataSource(String name) {
        this.name = name;
    }
    //往文件里写入数据!
    @Override
    public void writeData(String data) {
        File file = new File(name);
        try(FileOutputStream fos = new FileOutputStream(file)) {
            fos.write(data.getBytes(),0,data.length());
        } catch (IOException e) {
            System.out.println(e.getMessage());
        }
    }
    //从文件里读数据
    @Override
    public String readData() {
        char []buffer=null;
        File file = new File(name);
        try(FileReader reader=new FileReader(file)){
            buffer=new char[(int)file.length()];
            reader.read(buffer);
        }catch (IOException e){
            System.out.println(e.getMessage());
        }
        return new String(buffer);
    }
}

引入BASE64编码装饰器

这个装饰器就是我们做的功能增强!!

/**
 * @author linghu
 * @date 2024/7/5 9:46
 */
public class EncryptionDecorator implements DataSource{
    private DataSource dataSource;
    public EncryptionDecorator(DataSource dataSource) {
        this.dataSource = dataSource;
    }
    @Override
    public void writeData(String data) {
       dataSource.writeData(encode(data));
    }
    @Override
    public String readData() {
        return null;
    }
    //编码
    private String encode(String data){
        byte[] result = data.getBytes();
        //遍历result字节数组中的每个字节。然后,它通过将每个字节的值增加1来“编码”该字节。
        for (int i = 0; i < result.length; i++) {
            result[i] += (byte) 1;
        }
        return Base64.getEncoder().encodeToString(result);
    }
    //解码
    private String decode(String data) {
        byte[] result = Base64.getDecoder().decode(data);
        for (int i = 0; i < result.length; i++) {
            result[i] -= (byte) 1;
        }
        return new String(result);
    }
}

客户端Client

/**
 * @author linghu
 * @date 2024/7/5 9:38
 */
public class Client {
    public static void main(String[] args) {
        String salaryRecords = "Name,Salary / John Smith,100000 / Steven Jobs";
//        FileDataSource dataSource =
//                new FileDataSource("D:/tmp/linghu/a.txt");
        //装饰器模式
        EncryptionDecorator dataSource = new EncryptionDecorator(new FileDataSource("D:/tmp/linghu/a.txt"));
        dataSource.writeData(salaryRecords);
        //读取文件内容
        DataSource plain=new FileDataSource("D:/tmp/linghu/a.txt");
        System.out.println("--原始文件内容----");
        System.out.println(salaryRecords);
        System.out.println("--读取文件内容---");
        System.out.println(plain.readData());
    }
}

在这段代码里:

EncryptionDecorator dataSource = new EncryptionDecorator(new FileDataSource("D:/tmp/linghu/a.txt"));

其实就是加了一个装饰器 EncryptionDecorator,对文档里的字符做了解密。

我们执行:

我们现在把装饰器删掉,代码如下:

public class Client {
    public static void main(String[] args) {
        String salaryRecords = "Name,Salary / John Smith,100000 / Steven Jobs";
        FileDataSource dataSource =
                new FileDataSource("D:/tmp/linghu/a.txt");
        //装饰器模式
//        EncryptionDecorator dataSource = new EncryptionDecorator(new FileDataSource("D:/tmp/linghu/a.txt"));
        dataSource.writeData(salaryRecords);
        //读取文件内容
        DataSource plain=new FileDataSource("D:/tmp/linghu/a.txt");
        System.out.println("--原始文件内容----");
        System.out.println(salaryRecords);
        System.out.println("--读取文件内容---");
        System.out.println(plain.readData());
    }
}

我们在执行以下:

我们在取消这个装饰器以后,文件内容没有被加密了,我们读取到的自然就是明文了。


目录
相关文章
|
1月前
|
设计模式 Java
【设计模式】工厂模式(定义 | 特点 | Demo入门讲解)
【设计模式】工厂模式(定义 | 特点 | Demo入门讲解)
47 2
|
1月前
|
设计模式 传感器
【设计模式】观察者模式(定义 | 特点 | Demo入门讲解)
【设计模式】观察者模式(定义 | 特点 | Demo入门讲解)
37 0
|
3月前
|
设计模式
建模底层逻辑问题之以命令设计模式为例,要用定义法建模,如何实现
建模底层逻辑问题之以命令设计模式为例,要用定义法建模,如何实现
|
2月前
|
设计模式 Java
Java设计模式-装饰器模式(10)
Java设计模式-装饰器模式(10)
|
1月前
|
设计模式 算法 Java
【设计模式】策略模式(定义 | 特点 | Demo入门讲解)
【设计模式】策略模式(定义 | 特点 | Demo入门讲解)
16 0
|
2月前
|
设计模式 C# 开发者
C#设计模式入门实战教程
C#设计模式入门实战教程
|
3月前
|
设计模式 微服务
设计模式问题之在软件设计中,“模块”如何定义和区分
设计模式问题之在软件设计中,“模块”如何定义和区分
|
4月前
|
设计模式 安全 Java
Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
75 1
|
4月前
|
设计模式 Java 数据安全/隐私保护
Java中的设计模式:从入门到精通
Java中的设计模式:从入门到精通
|
5月前
|
设计模式 Java
Java设计模式:深入装饰器模式的三种写法(六)
Java设计模式:深入装饰器模式的三种写法(六)

热门文章

最新文章

  • 1
    C++一分钟之-设计模式:工厂模式与抽象工厂
    42
  • 2
    《手把手教你》系列基础篇(九十四)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-下篇(详解教程)
    46
  • 3
    C++一分钟之-C++中的设计模式:单例模式
    53
  • 4
    《手把手教你》系列基础篇(九十三)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-上篇(详解教程)
    37
  • 5
    《手把手教你》系列基础篇(九十二)-java+ selenium自动化测试-框架设计基础-POM设计模式简介(详解教程)
    61
  • 6
    Java面试题:结合设计模式与并发工具包实现高效缓存;多线程与内存管理优化实践;并发框架与设计模式在复杂系统中的应用
    56
  • 7
    Java面试题:设计模式在并发编程中的创新应用,Java内存管理与多线程工具类的综合应用,Java并发工具包与并发框架的创新应用
    40
  • 8
    Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
    49
  • 9
    Java面试题:请列举三种常用的设计模式,并分别给出在Java中的应用场景?请分析Java内存管理中的主要问题,并提出相应的优化策略?请简述Java多线程编程中的常见问题,并给出解决方案
    105
  • 10
    Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
    75