ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:50.88KB ,
资源ID:4042640      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/4042640.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Flyweight享元模式.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Flyweight享元模式.docx

1、Flyweight享元模式Flyweight享元模式作用:运用共享技术有效地支持大量细粒度的对象。内部状态intrinsic和外部状态extrinsic:1)Flyweight模式中,最重要的是将对象分解成intrinsic和extrinsic两部分。2)内部状态:在享元对象内部并且不会随环境改变而改变的共享部分,可以称为是享元对象的内部状态3)外部状态:而随环境改变而改变的,取决于应用环境,或是实时数据,这些不可以共享的东西就是外部状态了。4)内部状态和外部状态之间的区别:在Flyweight模式应用中,通常修改的是外部状态属性,而内部状态属性一般都是用于参考或计算时引用。Flyweight

2、执行时所需的状态必定是内部的或外部的。内部状态存储于ConcreteFlyweight对象之中;而外部状态则由Client对象存储或计算。当用户调用Flyweight对象的操作时,将该状态传递给它。以文字处理软件为例:内部状态存储于flyweight中,它包含了独立于flyweight场景的信息,这些信息使得flyweight可以被共享。如字符代码,字符大小外部状态取决于flyweight场景,并根据场景而变化,因此不可共享。用户对象负责在必要的时候将外部状态传递给flyweight,如字符位置,字符颜色UML图:解析:Flyweight:享元类的基类,定义一个接口,通过这个接口Flyweig

3、ht可以接受并作用于外部状态。ConcreteFlyweight:实现Flyweight接口, 并为内部状态( 如果有的话) 增加存储空间。ConcreteFlyweight对象必须是可共享的。它所存储的状态必须是内部的(intrinsic);即,它必须独立于ConcreteFlyweight对象的场景。UnsharedConcreteFlyweight:并非所有的Flyweight子类都需要被共享。Flyweight接口使共享成为可能,但它并不强制共享。在Flyweight对象结构的某些层次,UnsharedConcreteFlyweight对象通常将ConcreteFlyweight对象作

4、为子节点。FlyweightFactory:1) 创建并管理Flyweight对象。2)确保合理地共享Flyweight。当用户请求一个Flyweight时,FlyweightFactory对象提供一个已创建的实例或者创建一个(如果不存在的话)Client1)维持一个对Flyweight的引用。2)计算或存储一个(多个)Flyweight的外部状态。分析:享元模式可以避免大量非常相似类的开销。在程序设计中,有时需要生成大量细粒度的类实例来表示数据。如果能发现这些实例数据除了几个参数外基本都是相同的。有时就能够大幅度地减少实例化的类的数量。如果能把那些参数移到类实例的外面,在方法调用时将它们传递

5、进来,就可以通过共享大幅度地减少单个实例的数目。比如在文档编辑器的设计过程中,我们如果为没有字母创建一个对象的话,系统可能会因为大量的对象而造成存储开销的浪费。例如一个字母“a”在文档中出现了100000次,而实际上我们可以让这一万个字母“a”共享一个对象,当然因为在不同的位置可能字母“a”有不同的显示效果(例如字体和大小等设置不同),在这种情况我们可以为将对象的状态分为“外部状态”和“内部状态”,将可以被共享(不会变化)的状态作为内部状态存储在对象中,而外部对象(例如上面提到的字体、大小等)我们可以在适当的时候将外部对象最为参数传递给对象(例如在显示的时候,将字体、大小等信息传递给对象)。F

6、lyweight的内部状态是用来共享的,Flyweightfactory负责维护一个Flyweight池(存放内部状态的对象),当客户端请求一个共享Flyweight时,这个factory首先搜索池中是否已经有可适用的,如果有,factory只是简单返回送出这个对象,否则,创建一个新的对象,加入到池中,再返回送出这个对象.池为重复或可共享的对象、属性设置一个缓冲,称为内部状态。这些内部状态一般情况下都是不可修改的,也就是在第一个对象、属性被创建后,就不会去修改了(否则就没意义了)。Flyweight 对对象的内部状态进行共享,只为每种内部状态创建一个实例,对内部状态使用了单例模式。用户不应直接

7、对ConcreteFlyweight类进行实例化,而只能从FlyweightFactory对象得到ConcreteFlyweight对象,这可以保证对它们适当地进行共享。存储节约由以下几个因素决定:1) 因为共享,实例总数减少的数目2)对象内部状态的平均数目3) 外部状态是计算的还是存储的实现要点1)享元工厂维护一张享元实例表。2)享元不可共享的状态需要在外部维护。即删除外部状态:该模式的可用性在很大程度上取决于是否容易识别外部状态并将它从共享对象中删除。3)按照需求可以对享元角色进行抽象。4)管理共享对象:引用计数和垃圾回收何时采用1)如果一个应用程序使用了大量的对象,而大量的这些对象造成了

8、很大的存储开销时就应该考虑使用;2)还有就是对象的大多数状态可变为外部状态,如果删除对象的外部状态,那么可以用相对较少的共享对象取代很多组对象,此时可以考虑所使用享元模式。3)系统中有大量耗费了大量内存的细粒度对象,并且对外界来说这些对没有任何差别的(或者说经过改造后可以是没有差别的)。在文档编辑器例子中如果一个字符对应一个对象,那么一篇文档所要容纳的对象将是非常的庞大耗费大量的内存。而实际组成文档的字符是有限的,是由这些字符不同的组合和排列得到的。所以需要共享,将基本的字符进行共享,将使得字符对象变得有限。代码如下:Flyweight.h 1 #ifndef _FLYWEIGHT_H_ 2

9、#define _FLYWEIGHT_H_ 3 4 #include 5 #include 6 7 using namespace std; 8 9 /基类,定义操作接口Operation10 class Flyweight11 12 public:13 /操作外部状态extrinsicState14 virtual void Operation(const string& extrinsicState)=0;15 string GetIntrinsicState();16 virtual Flyweight();17 protected:18 Flyweight(string intrins

10、icState);19 private:20 /内部状态,也可以放在ConcreteFlyweight中21 string _intrinsicState;22 ;23 24 class ConcreteFlyweight:public Flyweight25 26 public:27 /实现接口函数28 virtual void Operation(const string& extrinsicState);29 ConcreteFlyweight(string intrinsicState);30 ConcreteFlyweight();31 ;32 33 class UnsharedCo

11、ncreteFlyweight:public Flyweight34 35 public:36 virtual void Operation(const string& extrinsicState);37 UnsharedConcreteFlyweight(string intrinsicState);38 UnsharedConcreteFlyweight();39 ;40 41 class FlyweightFactory42 43 public:44 FlyweightFactory();45 FlyweightFactory();46 /获得一个请求的Flyweight对象47 Fl

12、yweight* GetFlyweight(string key);48 /获取容器中存储的对象数量49 void GetFlyweightCount();50 protected:51 private:52 /保存内部状态对象的容器53 vector m_vecFly;54 ;55 #endifFlyweight.cpp 1 #include Flyweight.h 2 #include 3 4 using namespace std; 5 6 Flyweight:Flyweight(string intrinsicState) 7 8 this-_intrinsicState = intr

13、insicState; 9 10 11 Flyweight:Flyweight()12 13 14 string Flyweight:GetIntrinsicState()15 16 return this-_intrinsicState;17 18 19 ConcreteFlyweight:ConcreteFlyweight(string intrinsicState):Flyweight(intrinsicState)20 21 22 23 ConcreteFlyweight:ConcreteFlyweight()24 25 26 27 void ConcreteFlyweight:Ope

14、ration(const string& extrinsicState)28 29 cout GetIntrinsicState() endl;30 cout extrinsicState endl;31 32 33 UnsharedConcreteFlyweight:UnsharedConcreteFlyweight(string intrinsicState):Flyweight(intrinsicState)34 35 36 37 UnsharedConcreteFlyweight:UnsharedConcreteFlyweight()38 39 40 41 void UnsharedC

15、oncreteFlyweight:Operation(const string& extrinsicState)42 43 cout extrinsicState endl;44 45 46 FlyweightFactory:FlyweightFactory()47 48 49 FlyweightFactory:FlyweightFactory()50 51 52 /若该对象已存在,直接返回,否则新建一个对象,存入容器中,再返回53 Flyweight* FlyweightFactory:GetFlyweight(string key)54 55 vector:iterator iter =

16、this-m_vecFly.begin();56 for(;iter!= this-m_vecFly.end();iter+)57 58 if(*iter)-GetIntrinsicState() = key)59 60 return *iter;61 62 63 Flyweight* fly = new ConcreteFlyweight(key);64 this-m_vecFly.push_back(fly);65 return fly;66 67 68 void FlyweightFactory:GetFlyweightCount()69 70 cout m_vecFly.size()

17、endl;71 main.cpp 1 #include Flyweight.h 2 #include 3 #include 4 5 using namespace std; 6 7 int main() 8 9 /外部状态extrinsicState10 string extrinsicState = ext;11 12 /工厂对象,工厂对象13 FlyweightFactory* fc = new FlyweightFactory();14 15 /向工厂申请一个Flyweight对象,且该对象的内部状态值为“hello”16 Flyweight* fly = fc-GetFlyweight

18、(hello);17 18 Flyweight* fly1 = fc-GetFlyweight(hello);19 20 /应用外部状态21 fly-Operation(extrinsicState);22 23 fc-GetFlyweightCount();24 25 return 0;26 另外一个文本处理的例子参考:代码如下:Document.h 1 #ifndef _DOCUMENT_H_ 2 #define _DOCUMENT_H_ 3 4 #include 5 #include 6 7 using namespace std; 8 9 / The Flyweight abstrac

19、t class10 class character11 12 public:13 /析构函数14 virtual character();15 /应用外部状态16 virtual void Display(int width,int height,int ascent,int descent,int pointSize)=0;17 /获取内部状态18 virtual char GetSymbol()=0;19 protected:20 /*-内部状态-*/21 char symbol;22 /*-/23 24 /*-外部状态-*/25 int width;26 int height;27 in

20、t ascent;28 int descent;29 int pointSize;30 /*-*/31 /构造函数32 character(char c);33 ;34 35 /A ConcreteFlyweight class36 class characterA:public character37 38 public:39 characterA(char c);40 characterA();41 virtual void Display(int width,int height,int ascent,int descent,int pointSize);42 virtual char

21、GetSymbol();43 protected:44 private:45 ;46 47 /B ConcreteFlyweight class48 class characterB:public character49 50 public:51 characterB(char c);52 characterB();53 virtual void Display(int width,int height,int ascent,int descent,int pointSize);54 protected:55 private:56 ;57 58 /C ConcreteFlyweight cla

22、ss59 class characterC:public character60 61 public:62 characterC(char c);63 characterC();64 virtual void Display(int width,int height,int ascent,int descent,int pointSize);65 protected:66 private:67 ;68 69 /D ConcreteFlyweight class70 class characterD:public character71 72 public:73 characterD(char

23、c);74 characterD();75 virtual void Display(int width,int height,int ascent,int descent,int pointSize);76 protected:77 private:78 ;79 /*80 .81 */82 83 /The FlyweightFactory class84 class characterFactory85 86 public:87 characterFactory();88 characterFactory();89 /申请一个character对象90 character* GetChara

24、cter(char);91 /获取存储的character*数量92 vector:size_type GetCount();93 private:94 /保存character*的容器,可以换成List等其它容器95 vector m_vecCharacter;96 ;97 98 #endifDocument.cpp 1 #include Document.h 2 #include 3 4 character:character(char c) 5 6 this-symbol = c; 7 8 9 character:character()10 11 12 13 characterA:cha

25、racterA(char c):character(c)14 15 16 17 characterA:characterA()18 19 20 21 char characterA:GetSymbol()22 23 return this-symbol;24 25 26 void characterA:Display(int width,int height,int ascent,int descent,int pointSize)27 28 /接收并作用外部状态29 this-ascent = ascent;30 this-descent = descent;31 this-height =

26、 height;32 this-pointSize = pointSize;33 this-width = width;34 35 cout symbol 36 ascent 37 descent 38 height 39 pointSize 40 width endl;41 42 43 characterFactory:characterFactory()44 45 46 characterFactory:characterFactory()47 48 49 character* characterFactory:GetCharacter(char c)50 51 vector:iterat

27、or iter = this-m_vecCharacter.begin();52 for(;iter != this-m_vecCharacter.end();iter+)53 54 if(*iter)-GetSymbol() = c)55 56 return *iter;57 58 59 character* pf = new characterA(c);60 this-m_vecCharacter.push_back(pf);61 return pf;62 63 64 vector:size_type characterFactory:GetCount()65 66 return this

28、-m_vecCharacter.size();67 main.cpp 1 #include Flyweight.h 2 #include Document.h 3 #include 4 #include 5 6 using namespace std; 7 8 int main() 9 10 /存储外部状态11 int ascent = 70;12 int descent = 0;13 int height = 100;14 int width = 120;15 int pointSize = 10;16 17 string test = AABCDDEFGHI;18 string:iterator it = test.begin();19 c

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1