//---------------------------15/04/20----------------------------

//Flyweight 享元模式------对象结构型模式

/*

1:意图:

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

2:动机:

3:适用性:

以下条件都成立时才能使用。

1>一个应用程序使用了大量的对象。

2>完全由于使用大量的对象,造成很大的存储开销。

3>对象的大多数状态都可变为外部状态。

4>如果删除对象的外部状态,那么可以用相对较少的共享对象取代很多组对象。

5>应用程序不依赖于对象标识。由于Flyweight对象可以被共享,对于概念上明显有别的

对象,标识测试将返回真值。

4:结构:

FlyweightFactory:

flyweights--------------------------------->Flyweight:

GetFlyweight(key)                           Operation(extrinsicState)

{ if(flyweight[key] exists)                     |

return exisiting flyweight;                 |

else                                          |

create new flyweight;                       |

add it to pool of flyweights;               |

return the new flyweight;                   |

}    |                               ------------------------

|                               |                      |

|                |---->ConcreteFlyweight        |--->UnsharedConcreteFlyweight

Client------------|     Operation(extrinsicState)|    Operation(extrinsicState)

|     instrinsicState          |    allState

--------------------------------

5:参与者:

1>Flyweight

描述一个接口,通过这个接口flyweight可以接受并作用于外部状态。

2>ConcreteFlyweight

实现Flyweight接口,并为内部状态(如果有的话)增加存储空间。ConcreteFlyweight对象必须是

可共享的。它存储的内部状态必须和场景无关。

3>UnsharedConcreteFlyweight

并非所有的Flyweight子类都需要被共享。Flyweight接口使得共享成为可能,但是它并不强制共享。

UnsharedConcreteFlyweight对象通常把ConcreteFlyweight对象作为子节点。

4>FlyweightFactory

1)创建并管理flyweight对象。

2)确保合理地共享flyweight。拥有一个接口可以返回一个flyweight对象(如果不存在会创建一个)。

5>Client

1)维持一个对flyweight的引用。

2)计算或存储一个(或多个)flyweight的外部状态。

6:协作:

1>flyweight执行时所需的状态必定是内部的或外部的。内部状态存储于ConcreteFlyweight对象中;而

外部对象则由Client对象存储或计算。当用户调用flyweight的操作时,只需要把状态传递给它。

(就是operation的那个操作,可以传入一个状态,然后由ConcreteFlyweight对象实现操作)

2>用户不应该直接对ConcreteFlyweight类进行实例化,而只能从FlyweightFactory对象得到

ConcreteFlyweight对象。

关于这点,可以直接隐藏掉ConcreteFlyweight的定义,只通过工厂返回基类指针。

7:效果:

1>这个模式使用时间来换空间(大量),因为参数传输,工厂查找,外部状态的计算都会产生运行时的开销。

2>节省的空间由一下决定:

1)因为共享而减少的 实例总数目。

2)对象内部状态的 平均数目。

3)外部状态时 计算的 还是存储的。

总结起来:共享的Flyweight越多,节省越多。节省的量随着共享的状态(内部状态)的增多而增大。外部状态时

计算的而非存储的。则能节省大量存储。

8:实现:

1>删除外部状态

外部状态的数量和大小决定了Flyweight模式的可用性。如果外部状态很多而且存储要求高,那么删除

外部状态就没有意义了。最理想的情况是:外部状态可以由一个单独的对象结构计算得到,且该结构的

存储要求非常小。

2>管理共享对象

因为对象时共享的,所以用户不能直接对它进行实例化,通常FlyweightFactory可以帮助用户找到某个

特定的Flyweight对象。FlyweightFactory通常采用关联存储(set map)帮助用户查找感兴趣的

Flyweight对象。

9:代码示例:                                                                             */

//abstract Flyweight:声明了Flyweight的接口

class Glyph

{

public:

virtual ~Glyph();

virtual void Draw(Window*, GlyphContext&);

virtual void SetFont(Font*, GlyphContext&);

virtual Font* GetFont(GlyphContext&);

virtual void First(GlyphContext&);

virtual void Next(GlyphContext&);

virtual bool IsDone(GlyphContext&);

virtual Glyph* Current(GlyphContext&);

virtual void Insert(Glyph*,GlyphContext&);

virtual void Remove(GlyphContext&);

protected:

Glyph();

};

//ConcreteFlyweight:这里只需要ascii码就够了

class Character : public Glyph

{

public:

Character(char);

virtual void Draw(Window*, GlyphContext&);

private:

char _charcode;

};

//客户自己创建维护的 外部状态-字体

//由于是根据范围来确定字体,所以字体采取btree来存储,btree的最底层对应了相应的字体。

class GlyphContext

{

public:

virtual ~GlyphContext();

virtual void Next(int step = 1);

virtual Font* GetFont();

virtual void SetFont(Font*, int span = 1);

private:

int _index;

BTree* _fonts;

};

//工厂,可以返回具体的Flyweight对象

const int NCHARCODES = 128;

class GlyphFactory

{

public:

GlyphFactory();

virtual ~GlyphFactory();

virtual Character* CreateCharacter(char);

virtual Row* CreateRow();

virtual Column* CreateColumn();

private:

Character* _character[NCHARCODES];

};

转载于:https://www.cnblogs.com/boydfd/p/4983130.html

设计模式 笔记 享元模式 Flyweight相关推荐

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

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

  2. 大话设计模式笔记 享元模式

    享元模式(Flyweigh),运用共享技术有效地支持大量细粒度的对象. package flyweight;//可以接受并作用于外部状态 public abstract class Flyweight ...

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

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

  4. 设计模式:享元(FlyWeight)模式

    设计模式:享元(FlyWeight)模式 一.前言     享元(FlyWeight)模式顾名思义,既是轻量级的,原因就是享元,共享元素,这里的元素指的是对象.如何共享对象,那就是在检测对象产生的时候 ...

  5. 设计模式(十)享元模式Flyweight(结构型)

    设计模式(十)享元模式Flyweight(结构型) 说明: 相对于其它模式,Flyweight模式在PHP实现似乎没有太大的意义,因为PHP的生命周期就在一个请求,请求执行完了,php占用的资源都被释 ...

  6. .net设计模式 (享元模式)学习笔记

    运用设计模式只是为了解决一类问题的,当解决掉当前一类问题,通常会在解决这个问题时候 带来其他问题  合理应用扬长避短 结构性设计模式:关注的是类与类之间的关系 .net设计模式 (享元模式)学习笔记 ...

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

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

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

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

  9. java23设计模式---class10、享元模式(FlyWeight)

    文章目录 一.基本介绍 1.定义 2.优点 3.缺点 4.角色 1)抽象享元类 2)具体享元类 3)享元工厂类 4)组合享元类 5.内部状态和外部状态 二.应用情景 1.线程池 2.String 3. ...

  10. 北风设计模式课程---享元模式

    北风设计模式课程---享元模式 一.总结 一句话总结: 不仅要通过视频学,还要看别的博客里面的介绍,搜讲解,搜作用,搜实例 1.享元模式的本质是什么? 池技术:各种缓存池都是享元模式的体现 说到享元模 ...

最新文章

  1. 6、SpringBoot+Mybatis整合------参数传递
  2. 小学计算机课总目标,小学信息技术课堂教学目标的确定与实现
  3. python列表导出csv_将Python列表导出到csv
  4. 苹果iPad视觉设计分析
  5. 在php storm中怎么搭建环境,PhpStorm搭建git环境
  6. TypeError系列之:TypeError: 'tuple' object does not support item assignment
  7. bean的作用域和生命周期
  8. 惨痛教训,事实证明ACER 4710无法使用双芯片的内置蓝牙
  9. 5天一充不是梦!最大电池容量手机发布:朴实感人 还能防身...
  10. 丰巢回应小学生用照片“刷脸”取件;苹果明年或发布四款 5G 手机;Spring Boot 2.2.0 发布 | 极客头条...
  11. [Linux] day03——REHL部署
  12. 【Matlab】mat2cell用法
  13. 网络爬虫之正则表达式
  14. 面部捕捉技术_FT45面部表情捕捉系统--说明书(中文版)
  15. VS 错误: cout 不明确
  16. 超强大的货币汇率实时查询工具
  17. DHCP和域的概念知识
  18. 计算多列迭代次数的一种平均列近似方法
  19. 【Javascript】进阶之实现评论分页与发表评论功能
  20. GRP-U8如何修改账套主管

热门文章

  1. tarjan 算法模板
  2. iOS Mac终端 生成模拟器与真机都能运行的.a静态库
  3. GitHub 热榜:不用 PS,一键去除照片中的对象,这个神器可试玩
  4. 已经被说“烂”的微服务,到底是个什么鬼?通过拆分实战案例来带你入门。...
  5. 从把三千行代码重构成15行代码谈起—好牛X的哟!!
  6. CMDB数据库设计-四种方案任你选
  7. 年轻时不多闯闯,老了拿什么来吹
  8. 这些小工具让你的Android开发更高效
  9. linux中级之keepalived概念
  10. linux进阶之子网划分