• 设计模式 - 享元模式


    目录

    一. 前言

    二. 实现


    一. 前言

        享元模式(Flyweight Pattern)是一种结构型设计模式,它主要解决的问题是创建大量相似对象时的内存开销问题。该模式通过共享具有相同状态的对象来减少内存使用量。

        享元模式的思想是:当需要创建一个新对象时,首先检查是否已经存在具有相同状态的对象。如果存在,则返回已经存在的对象,否则创建一个新的对象。因此,如果要创建多个具有相同状态的对象,可以重复使用相同的对象,从而减少内存开销。

        通过运用共享技术来有效地支持大量细粒度对象的复用。它通过共享已经存在的对象来大幅度减少需要创建 的对象数量、避免大量相似对象的开销,从而提高系统资源的利用率。

    二. 实现

    Flyweight: 享元对象
    IntrinsicState: 内部状态,享元对象共享内部状态,不会随着环境的改变而改变的可共享部分
    ExtrinsicState: 外部状态,每个享元对象的外部状态不同

    1. public interface Flyweight {
    2. void doOperation(String extrinsicState);
    3. }
    1. public class ConcreteFlyweight implements Flyweight {
    2. private String intrinsicState;
    3. public ConcreteFlyweight(String intrinsicState) {
    4. this.intrinsicState = intrinsicState;
    5. }
    6. @Override
    7. public void doOperation(String extrinsicState) {
    8. System.out.println("Object address: " + System.identityHashCode(this));
    9. System.out.println("IntrinsicState: " + intrinsicState);
    10. System.out.println("ExtrinsicState: " + extrinsicState);
    11. }
    12. }
    1. public class FlyweightFactory {
    2. private HashMap flyweights = new HashMap<>();
    3. Flyweight getFlyweight(String intrinsicState) {
    4. if (!flyweights.containsKey(intrinsicState)) {
    5. Flyweight flyweight = new ConcreteFlyweight(intrinsicState);
    6. flyweights.put(intrinsicState, flyweight);
    7. }
    8. return flyweights.get(intrinsicState);
    9. }
    10. }
    1. public class Client {
    2. public static void main(String[] args) {
    3. FlyweightFactory factory = new FlyweightFactory();
    4. Flyweight flyweight1 = factory.getFlyweight("aa");
    5. Flyweight flyweight2 = factory.getFlyweight("aa");
    6. flyweight1.doOperation("x");
    7. flyweight2.doOperation("y");
    8. }
    9. }
    1. Object address: 1163157884
    2. IntrinsicState: aa
    3. ExtrinsicState: x
    4. Object address: 1163157884
    5. IntrinsicState: aa
    6. ExtrinsicState: y

    经典应用实例为:俄罗斯方块,内部状态为各自的图形(L型、I型、J型、田型、Z型等),外部状态为颜色、位置等。

    JDK案例
    Java 利用缓存来加速大量小对象的访问时间。
    java.lang.Integer#valueOf(int)
    java.lang.Boolean#valueOf(boolean)
    java.lang.Byte#valueOf(byte)
    java.lang.Character#valueOf(char)

  • 相关阅读:
    Qt+Opencv+Ffmpeg实时摄像头数据推流,并在WEB端显示
    深度探讨容器化技术在网络安全中的应用与挑战
    代替虚拟化云安全工程师的解决方案
    fltp备份文件后统计验证
    Oozie 集成 Sqoop
    vscode debug go
    【发版】java项目一键式发版,一键式发版脚本,如何实现一键式发版
    C++项目实战--线程池代码讲解
    Pytorch实现深度学习常见问题
    74. 搜索二维矩阵
  • 原文地址:https://blog.csdn.net/mrluo735/article/details/133299666