博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
享元模式
阅读量:2394 次
发布时间:2019-05-10

本文共 2366 字,大约阅读时间需要 7 分钟。

享元模式的意图是运用共享技术有效地支持大量细粒度的对象。也就是说在一个系统中如果有多个相同的对象,那么只共享一份就可以,不必每个都去实例化一个对象。在 Flyweight 模式中,由于要产生各种各样的对象,所以在Flyweight 模式中常出现 Factory模式。Flyweight的内部状态是用来共享的,Flyweight factory负责维护一个对象存储池来存放内部状态的对象。Flyweight模式是一个提高程序效率和性能的模式,会大大加快程序的运行速度
享元模式原理
享元对象能做到共享的关键是区分内蕴状态和外蕴状态。一个内蕴状态是存储在享元对象内部的,并且不会随环境改变而有所不同,因此,一个享元可以具有内蕴状态并可以共享。一个外蕴状态是随环境改变而改变的,不可以共享状态。享元对象的外蕴状态必须由客户端保存,并且享元对象被创建之后,在需要使用的时候再传到享元对象内部。外蕴状态不可以影响享元对象的内蕴状态,它们是相互独立的,所有的内蕴状态在对象创建完后就不可再改变
享元模式设计初衷
面向对象语言的原则就是一切皆对象,但是如果正真使用起来,有时对象可能显得很庞大,创建很多对象无意消耗内存,那要“求同存异”找出这些对象群的共同特点,设计一个元类,封装可以被共享的类,还有一些特性是取决于应用,是不可共享的
享元模式类图
案例:咖啡店卖咖啡,只区分咖啡味,咖啡店只卖20种咖啡,有1W个订单,就没有必要生成1W个订单对象
public abstract class Order {
  // 卖出动作
  public abstract void sell();
  // 获取味道
  public abstract String getFlavor();
}
public class FlavorOrder extends Order {
  private String flavor;
  public FlavorOrder(String flavor) {
  this .flavor = flavor;
  }
  @Override
  public void sell() {
  System. out .println("卖出一杯[" + flavor + "]" );
  }
  @Override
  public String getFlavor() {
  return this .flavor ;
  }
}
public class FlavorFactory {
  // 订单池
  private Map<String, Order> flavorPool = new HashMap<String, Order>(20);
  // 静态工厂,负责生成订单对象
  private static FlavorFactory flavorFactory = new FlavorFactory();
  private FlavorFactory() {
  }
  public static FlavorFactory getInstance() {
  return flavorFactory ;
  }
  /**
  * 获得订单
  *
  * @return
  */
  public Order getOrder(String flavor) {
  Order order = null ;
  if (flavorPool .containsKey(flavor)) {
  order = flavorPool .get(flavor);
  } else {
  order = new FlavorOrder(flavor);
  flavorPool .put(flavor, order);
  }
  return order;
  }
  public int getTotalFlavorsMade() {
  return flavorPool .size();
  }
}
public class Client {
  private static List<Order> orders = new ArrayList<Order>(100);
  private static FlavorFactory flavorFactory;
  private static void takeOrders(String flavor) {
  orders .add(flavorFactory .getOrder(flavor));
  }
  public static void main(String[] args) {
  flavorFactory = FlavorFactory.getInstance();
  // 各种味道只生成一次,其中只保存对应的引用,这要这样可以有效减少对象的生成数量
  takeOrders( "拿铁");
  takeOrders( "卡布奇诺");
  takeOrders( "香草星冰乐");
  takeOrders( "拿铁");
  takeOrders( "卡布奇诺");
  takeOrders( "香草星冰乐");
  takeOrders( "拿铁");
  takeOrders( "卡布奇诺");
  takeOrders( "香草星冰乐");
  }
}
享元模式适用性
1> 一个应用程序使用大量的对象
2> 完全由于使用大量的对象,造成很大的存储开销
3> 对象的大多数状态都可以变为外部状态
4> 如果删除对象的外部状态,那么可以用相对较少的共享对象取代很多组对象
5> 引用程序不依赖对象标识
享元模式的有点及缺点
1> 享元模式使得系统更加复杂,为了使对象可以共享,需要将一些状态外部化,这使得程序的逻辑复杂化
2> 享元模式将享元对象的状态外部化,而读取外部状态使得运行时间稍微变长
你可能感兴趣的文章
停车费上涨需要公开“大数据”
查看>>
DirectFB代码导读
查看>>
Cocos2dx3.2从零开始【四】继续。
查看>>
sphinx教程2__安装、配置和使用
查看>>
《云计算架构技术与实践》序言(李德毅院士)
查看>>
SANS FOR572 Logstash
查看>>
FreeBSD kernel NFS client local vulnerabilities
查看>>
Yacc使用
查看>>
C语言里面的嵌套声明的读法
查看>>
桥接模式-通俗的理解(转)
查看>>
MXML 文件中的xmlns是什么意思?
查看>>
Flex Builder 中的工作空间、项目
查看>>
Flex 获得远程数据
查看>>
Flash Builder 4字体设置
查看>>
OpenGL坐标系
查看>>
C++用new和不用new创建类对象区别
查看>>
VS2008快捷键大全
查看>>
Mysql Fabric实现学习笔记
查看>>
Spring JTA multiple resource transactions in Tomcat with Atomikos example
查看>>
How to setup multiple data sources with Spring and JPA
查看>>