场景
让我们先来复习下java中String类型的特性:
1.String类型的对象一旦被创造就不可改变;
2.当两个String对象所包含的内容相同的时候,JVM只创建一个String对象对应这两个不同的对象引用。

先来验证下第二个特性:
public class TestPattern {
public static void main(String[] args){
String n = “I Love Java”;
String m = “I Love Java”;
System.out.println(n==m);
}
}
这段代码会告诉你n==m是true,这就说明了在JVM中n和m两个引用了同一个String对象

那么接着验证下第一个特性:
在系统输出之前加入一行代码“m = m + “hehe”;
这时候n==m结果为false,在执行后添加语句时,m指向了一个新创建的String对象,而不是修改引用的对象。

String类型的设计避免了在创建N多的String对象时产生的不必要的资源损耗,可以说是享元模式应用的范例!

意图
运用共享技术有效的支持大量细粒度的对象。

结构
(1) 内蕴状态存储在享元内部,不会随环境的改变而有所不同,是可以共享的。
(2) 外蕴状态是不可以共享的,它随环境的改变而改变的,因此外蕴状态是由客户端来保持(因为环境的变化是由客户端引起的)。
UML结构图
(1) 抽象享元角色:为具体享元角色规定了必须实现的方法,而外蕴状态就是以参数的形式通过此方法传入。在Java中可以由抽象类、接口来担当。
(2) 具体享元角色:实现抽象角色规定的方法。如果存在内蕴状态,就负责为内蕴状态提供存储空间。
(3) 享元工厂角色:负责创建和管理享元角色。要想达到共享的目的,这个角色的实现是关键!
(4) 客户端角色:维护对所有享元对象的引用,而且还需要存储对应的外蕴状态。

使用场景
如果一个应用程序使用了大量的对象,而这些对象造成了很大的存储开销的时候就可以考虑是否可以使用享元模式。
例如,如果发现某个对象的生成了大量细粒度的实例,并且这些实例除了几个参数外基本是相同的,如果把那些共享参数移到类外面,在方法调用时将他们传递进来,就可以通过共享大幅度单个实例的数目。

示例
典型的享元模式的例子为文书处理器中以图形结构来表示字符。
一个做法是,每个字形有其字型外观, 字模 metrics, 和其它格式资讯,但这会使每个字符就耗用上千字节。
取而代之的是,每个字符参照到一个共享字形物件,此物件会被其它有共同特质的字符所分享;只有每个字符(文件中或页面中)的位置才需要另外储存。
以下程式用来解释上述的文件例子。

public enum FontEffect {BOLD, ITALIC, SUPERSCRIPT, SUBSCRIPT, STRIKETHROUGH
}
public final class FontData {private static final WeakHashMap<FontData, WeakReference<FontData>> FLY_WEIGHT_DATA = new WeakHashMap<FontData, WeakReference<FontData>>();private final int pointSize;private final String fontFace;private final Color color;private final Set<FontEffect> effects;private FontData(int pointSize, String fontFace, Color color, EnumSet<FontEffect> effects) {this.pointSize = pointSize;this.fontFace = fontFace;this.color = color;this.effects = Collections.unmodifiableSet(effects);}public static FontData create(int pointSize, String fontFace, Color color, FontEffect... effects) {EnumSet<FontEffect> effectsSet = EnumSet.noneOf(FontEffect.class);for (FontEffect fontEffect : effects) {effectsSet.add(fontEffect);}// We are unconcerned with object creation cost, we are reducing overall memory consumptionFontData data = new FontData(pointSize, fontFace, color, effectsSet);// Retrieve previously created instance with the given values if it (still) existsWeakReference<FontData> ref = FLY_WEIGHT_DATA.get(data);FontData result = (ref != null) ? ref.get() : null; // Store new font data instance if no matching instance existsif (result == null) {FLY_WEIGHT_DATA.put(data, new WeakReference<FontData>(data));result = data;}// return the single immutable copy with the given valuesreturn result;}@Overridepublic boolean equals(Object obj) {if (obj instanceof FontData) {if (obj == this) {return true;}FontData other = (FontData) obj;return other.pointSize == pointSize && other.fontFace.equals(fontFace) && other.color.equals(color) && other.effects.equals(effects);}return false;}@Overridepublic int hashCode() {return (pointSize * 37 + effects.hashCode() * 13) * fontFace.hashCode();}// Getters for the font data, but no setters. FontData is immutable.
}

这个例子用来解释享元模式利用只载立执行立即小任务所必需的资料,因而减少内存使用量。

设计模式之---享元模式(Flyweight Pattern)相关推荐

  1. 【设计模式自习室】享元模式 Flyweight Pattern:减少对象数量

    前言 <设计模式自习室>系列,顾名思义,本系列文章带你温习常见的设计模式.主要内容有: 该模式的介绍,包括: 引子.意图(大白话解释) 类图.时序图(理论规范) 该模式的代码示例:熟悉该模 ...

  2. 享元模式(Flyweight Pattern)详解

    https://www.cnblogs.com/amei0/p/7930013.html 享元模式(Flyweight Pattern) 定义: 采用一个共享来避免大量拥有相同内容对象的开销.这种开销 ...

  3. Net设计模式实例之享元模式( Flyweight Pattern)

    一.享元模式简介(Brief Introduction) 享元模式(Flyweight Pattern),运用共享技术有效支持大量细粒度的对象. Use sharing to support larg ...

  4. 设计模式(结构型)之享元模式(Flyweight Pattern)

    PS一句:最终还是选择CSDN来整理发表这几年的知识点,该文章平行迁移到CSDN.因为CSDN也支持MarkDown语法了,牛逼啊! [工匠若水 http://blog.csdn.net/yanbob ...

  5. 设计模式:享元模式(Flyweight Pattern)

    1.享元模式:也叫蝇量模式,运行共享技术有效的支持大量细粒度的对象. 2.享元模式常用于系统底层开发,解决系统的性能问题.比如数据库连接池,里面都是创建好的连接对象. 3.享元模式能够解决重复对象的内 ...

  6. 设计模式之享元模式(Flyweight)摘录

    23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于如何创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而 ...

  7. 享元模式 Flyweight Pattern

    享元模式的定义为:采用一个共享来避免大量拥有相同内容对象的开销. 这种开销中最常见.直观的就是内存的损耗.享元模式以共享的方式高效地支持大量的细粒度对象. 在名字和定义中都体现了共享这个核心概念,那么 ...

  8. 26享元模式(Flyweight Pattern)

    面向对象的代价     面向对象很好地解决了系统抽象性的问题,同时在大多数情况下,也不会损及系统的性能.但是,在 某些特殊的应用中下,由于对象的数量太大,采用面向对象会给系统带来难以承受的内存开销.比 ...

  9. 设计模式(18):结构型-享元模式(Flyweight)

    设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. 毫无疑问,设计模式于 ...

  10. 享元模式 FlyWeight 结构型 设计模式(十五)

    享元模式(FlyWeight)  "享"取"共享"之意,"元"取"单元"之意. 意图 运用共享技术,有效的支持大量细粒度 ...

最新文章

  1. 嵌入式C程序基础与编程结构
  2. HtmlDocument
  3. 5G 标准 — R15
  4. 【测试面试题】控制体重
  5. 地图查询定位功能(Flex API)
  6. Java面试问题汇总(Redis)
  7. 帧起始定界符_检测帧起始定界符的方法、装置、设备及计算机存储介质与流程...
  8. Linux软件包安装和卸载
  9. TensorFlow2.0:自定义层与自定义网络
  10. python3 format用法_python3 str.format()的使用
  11. Step by Step-构建自己的ORM系列-ORM改进方案思考(上)
  12. 微信小程序云开发教程-分页查询
  13. 数据库DB2性能优化高级进阶
  14. Git下载连接远程仓库
  15. 单片机实验(十一)单片机独立按键控制LED
  16. python实现白色背景转为透明背景
  17. 反向代理服务器nginx
  18. 别费劲找站长工具共享VIP了 这个工具也不错
  19. ddraw 的blt 方法
  20. 白竹机器人_白术防风黄芪功效作用

热门文章

  1. 微信小程序-订单页面——可左右滑动(附源码)
  2. 最长上升子序列、最长公共子序列、最长公共上升子序列(LIS、LCS、LCIS)
  3. 171103 逆向-内存与外挂(培训提纲)
  4. Verilog 流水线设计 Pipeline
  5. 【C语言】3天速刷C语言(指针初识)
  6. 对如何分析项目的思考
  7. Linux下安装Python2.7
  8. 重庆封闭式计算机学校有哪些,哪里有全封闭小学?重庆哪儿有全封闭式学校
  9. error RC2176 : old DIB in res/****.ico; pass it through SDKPAINT
  10. C语言之复合类型上卷(十八)(阴阳两极)