概念
- 享元模式(Flyweight Pattern),运用共享技术有效地支持大量细粒度对象的复用。系统只使用少量的对象,而这些对象都很相似,状态变化很小,可以实现对象的多次复用。对象结构型
- 在享元模式中可以共享的相同内容称为内部状态(IntrinsicState),而那些需要外部环境来设置的不能共享的内容称为外部状态(Extrinsic State),由于区分了内部状态和外部状态,因此可以通过设置不同的外部状态使得相同的对象可以具有一些不同的特征,而相同的内部状态是可以共享的。
- 在享元模式中通常会出现工厂模式,需要创建一个享元工厂来负责维护一个享元池(Flyweight Pool)用于存储具有相同内部状态的享元对象。

主要角色
- Flyweight: 抽象享元类 Connection
- ConcreteFlyweight: 具体享元类 ConnectionImpl(user,pwd,url)
- UnsharedConcreteFlyweight: 非共享具体享元类ConnectionImpl(state)
- FlyweightFactory: 享元工厂类;简单工厂,产品就一个Connection
```java
/**
- 具体享元类 */ @AllArgsConstructor public class BeautifulWaitress extends AbstractWaitressFlyweight{ String id;//工号 String name;//名字 int age;//年龄 //以上是不变的
@Overridevoid service() {System.out.println("工号:"+id+";"+name+" "+age+" 正在为您服务...");//改变外部状态this.canService = false;}@Overridevoid end() {System.out.println("工号:"+id+";"+name+" "+age+" 服务结束...请给五星好评");this.canService = true;}
}
```java/*** 足道店:这相当于享元工厂* 店里面很多服务员。** 享元和原型* 1、享元返回的是这个本人。* 2、原型返回的是克隆人。* FlyweightFactory: 享元工厂类*/public class ZuDao {private static Map<String,AbstractWaitressFlyweight> pool = new HashMap<>();//享元,池子中有对象static {BeautifulWaitress waitress =new BeautifulWaitress("1111","张三",18);BeautifulWaitress waitress2 =new BeautifulWaitress("9527","李四",20);pool.put(waitress.id,waitress);pool.put(waitress2.id,waitress2);}public void addWaitress(AbstractWaitressFlyweight waitressFlyweight){pool.put(UUID.randomUUID().toString(),waitressFlyweight);}public static AbstractWaitressFlyweight getWaitress(String name){AbstractWaitressFlyweight flyweight = pool.get(name);if(flyweight == null){for (AbstractWaitressFlyweight value : pool.values()) {//当前共享对象能否是否if(value.isCanService()){return value;}};return null;}return flyweight;}}
应用场景
- 典型的代表:数据库连接池
- 所有的池化技术
- 享元和原型模式有什么区别?享元是预先准备好的对象进行复用,原型没法确定预先有哪些
