【设计模式】享元模式

  • 享元模式属于结构型设计模式

    核心思想是通过共享技术,实现相似对象的高效复用。用 1%的资源支撑100%的需求------通过对象状态的分离与共享,用最小内存支持海量对象

    内部状态:对象中不变的部分共享

    外部状态:对象中变化的部分非共享

适用场景

  • 系统中存在大量相似或相同的对象
  • 对象创建/销毁成本较高
  • 对象状态可以外部变化,即对象状态独立于对象本身存在。

核心组件

  • 享元接口:定义外部状态的方法,规定可以共享的状态
  • 实现类:实现类,存储内部状态,实现具体业务逻辑
  • 享元工厂:用于对象池的管理,控制对象的创建和复用

类图

java 复制代码
//抽象 享元类
public abstract class AbstractBikeFlyWeight {

    private String color;

    private int price;

    public AbstractBikeFlyWeight(String color, int price) {
        this.color = color;
        this.price = price;
    }
    
    
    public abstract String show();

}
//实现类
public class OneBike extends AbstractBikeFlyWeight {
    

    public OneBike(String color, int price) {
        super(color, price);
    }

    @Override
    public String show() {
        return "one bike color: " + color + " price: " + price;
    }
}

public class TwoBike extends AbstractBikeFlyWeight {

    public TwoBike(String color, int price) {
        super(color, price);
    }

    @Override
    public String show() {
        return "two bike color: " + color + " price: " + price;
    }
}

//工厂
public class Factory {

    private static Map<String,AbstractBikeFlyWeight> bikeMapping = new HashMap<>();

    public static AbstractBikeFlyWeight getBike(String color, String type) {
        String key = color + type;

        if (bikeMapping.containsKey(key)) {
            return bikeMapping.get(key);
        }else  {
            AbstractBikeFlyWeight bike;
            switch (color) {
                case "one":
                    bike = new OneBike();
                    break;
                case "two":
                    bike = new TwoBike();
                    break;
                default:
                    throw new IllegalArgumentException("Invalid color: " + color);
            }
            bike.setColor(color);
            bike.setType(type);
            return bike;
        }

    }

}

模式的优点缺点

优点

  • 内存优化:可以减少对象的存储
  • 性能提升:降低GC压力,提高缓存命中率
  • 资源复用:避免重复资源的浪费

缺点

  • 增加系统的复杂性:需要区分可共享和不可共享的逻辑
  • 需要考虑线程安全的场景

总结

当系统面临对象数量爆炸性增长,占用内存过大的情况,可以考虑是否使用享元模式。同时还要确认对象是否存在可复用的逻辑以及多少状态可以在外部传递进行处理。

相关推荐
张较瘦_10 小时前
[论文阅读] 软件工程 | 告别“线程安全玄学”:基于JMM的Java类静态分析,CodeQL3分钟扫遍GitHub千仓错误
java·论文阅读·安全
A尘埃12 小时前
智慧零售全渠道业务中台系统
java·零售
尘鹄12 小时前
go 初始化组件最佳实践
后端·设计模式·golang
小wanga15 小时前
C++知识
java·开发语言·c++
我是渣哥15 小时前
Java String vs StringBuilder vs StringBuffer:一个性能优化的探险故事
java·开发语言·jvm·后端·算法·职场和发展·性能优化
工一木子15 小时前
深入Java并发:锁机制原理剖析与性能优化实战
java·性能优化·并发·
你我约定有三15 小时前
java--写在 try 中的创建连接
java·开发语言
ERP老兵-冷溪虎山15 小时前
Python/JS/Go/Java同步学习(第三篇)四语言“切片“对照表: 财务“小南“纸切片术切凭证到崩溃(附源码/截图/参数表/避坑指南/老板沉默术)
java·javascript·python·golang·中医编程·四语言同步学习·职场生存指南
科技树支点15 小时前
无GC的Java创新设计思路:作用域引用式自动内存管理
java·python·go·web·编程语言·编译器