• 设计模式 - 享元模式


    目录

    一. 前言

    二. 实现


    一. 前言

        享元模式(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)

  • 相关阅读:
    对抗训练理论分析:自适应步长快速对抗训练
    【mysql】出现 slow sql 问题及建议
    面向6G承载网的路由优化算法研究
    基于HTML旅游网站项目的设计与实现——联途旅游网服务平台网站HTML模板HTML+CSS+JavaScript
    条件期望:Conditional Expectation 举例详解之入门之入门之草履虫都说听懂了
    测试22222
    【PAT甲级 - C++题解】1007 Maximum Subsequence Sum
    Python 算法高级篇:桶排序与基数排序
    【深度学习实验】前馈神经网络(final):自定义鸢尾花分类前馈神经网络模型并进行训练及评价
    Python 自动化Web测试
  • 原文地址:https://blog.csdn.net/mrluo735/article/details/133299666