Flyweight(享元)--对象结构型模式

1.意图

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

2.动机

Flyweight模式描述了如何共享对象,使得可以细粒度地使用它们,而无需高昂的代价。flyweight是一个共享对象,它可以同时在多个场景(context)中使用,并且在每个场景中flyweight都可以作为一个独立的对象---这一点与非共享对象的实例没有区别。

3.适用性

  • 一个应用程序使用了大量的对象。
  • 完全由于使用大量的对象,造成很大的存储开销。
  • 对象的大多数状态都可变为外部状态。
  • 如果删除对象的外部状态,那么可以用相对较少的共享对象取代很多组对象。
  • 应用程序不依赖于对象标识。由于Flyweight对象可以被共享,对于概念上明显有别的对象,标识测试将返回真值。

4.结构图

5.代码实例

//Flyweight.h

#include <string>

class FlweightGraphicBase
{
public:
    virtual void PrintColor()=0;
protected:
    std::string m_Color;
};

class FlweightWhiteGraphic : public FlweightGraphicBase
{
public:
    FlweightWhiteGraphic();
    void PrintColor();
};

class FlweightBlackGraphic : public FlweightGraphicBase
{
public:
    FlweightBlackGraphic();
    void PrintColor();
};
//FlyweigtFactory.h

#include <string>
#include <memory>
#include <map>

class FlweightGraphicBase;

class FlyweightFactory
{
public:
    std::shared_ptr<FlweightGraphicBase> GetFlyweight(std::string sColor);
    void SetFlyweight(std::string sColor,
        std::shared_ptr<FlweightGraphicBase> pFlyweight);

private:
    std::map <std::string,std::shared_ptr<FlweightGraphicBase>> m_mapFlyweight;
};
//Flyweight.cpp

#include "Flyweight.h"
#include <iostream>

FlweightWhiteGraphic::FlweightWhiteGraphic()
{
    m_Color = "White";
}

void FlweightWhiteGraphic :: PrintColor()
{
    std::cout<<"Color is :" << m_Color << std::endl;
}

FlweightBlackGraphic::FlweightBlackGraphic()
{
    m_Color = "Black";
}

void FlweightBlackGraphic :: PrintColor()
{
    std::cout<<"Color is :" << m_Color << std::endl;
}
//FlyweightFactory.cpp

#include "FlyweightFactory.h"

std::shared_ptr<FlweightGraphicBase> FlyweightFactory::GetFlyweight(std::string sColor)
{
    auto iter = m_mapFlyweight.find(sColor);
    if(iter == m_mapFlyweight.end())
    {
        return nullptr;
    }

    return iter->second;
}

void FlyweightFactory::SetFlyweight(std::string sColor,
        std::shared_ptr<FlweightGraphicBase> pFlyweight)
{
    m_mapFlyweight[sColor] = pFlyweight;
}
//Client.cpp

#include "Flyweight.h"
#include "FlyweightFactory.h"
#include <iostream>

void Insert(std::string sColor,
    int index,std::shared_ptr<FlweightGraphicBase> pFlweightGraphic)
{
    std::cout<<"Posion " << index << " Insert: " << sColor << std::endl ;
}

int main()
{
    std::shared_ptr<FlyweightFactory> pFlyweightFactory(new FlyweightFactory);
    std::shared_ptr<FlweightWhiteGraphic> pFlweightWhiteGraphic(new FlweightWhiteGraphic);
    std::shared_ptr<FlweightBlackGraphic> pFlweightBlackGraphic(new FlweightBlackGraphic);

    pFlyweightFactory->SetFlyweight("White",pFlweightWhiteGraphic);
    pFlyweightFactory->SetFlyweight("Black",pFlweightBlackGraphic);

    auto pFlyweight = pFlyweightFactory->GetFlyweight("White");
    Insert("White",0,pFlyweight);

    pFlyweight = pFlyweightFactory->GetFlyweight("Black");
    Insert("Black",1,pFlyweight);

    pFlyweight = pFlyweightFactory->GetFlyweight("White");
    Insert("White",2,pFlyweight);

    pFlyweight = pFlyweightFactory->GetFlyweight("Black");
    Insert("Black",3,pFlyweight);

    while(1);

}

6.测试结果

实例代码中 所有插入的Graphic 共享黑白两种颜色,位置信息存储在外部。

7.效果

  • 存储节约,和以下因素有关:
  • 1.因为共享,实例总数减少的数目。
  • 2.对象内部状态的平均数目。
  • 3.外部状态是计算的还是存储的。
时间: 2024-10-11 22:21:26

Flyweight(享元)--对象结构型模式的相关文章

Flyweight 享元(结构型)

一:描述:(该模式实际应用较少) Flyweight 享元模式是对大量细粒度的元素进行共享和重用.减少对象的创建减轻内存: 注和单例模式不同的是:享元模式的各个对象佣有各自的行为并可实例化,单例模式的各个对象佣有一样的行为并不可直接实例化. 二:模式图: 三:实现代码简单例子: 1.创建抽像的享元类 2.创建共享的享元对象(可以有很多这种对像) 3.创建非共享的享元对象 4.创建享元的工厂 5.客端的使用和效果;

设计模式之十三:Flyweight(享元)—对象结构型模式

2014-06-15 星期日 9:35:04  Flyweight,继续GOF. 1.Intent Use sharing to support large numbers of fine-grained objects efficiently. 运用共享技术有效地支持大量细粒度的对象. 2.Also Known As 3.Motivation A flyweightis a shared object that can be used in multiple contexts simultan

设计模式之十四:Decorator(装饰)—对象结构型模式

2014-06-15 星期日 10:42:12  Decorator,继续GOF. 1.Intent Attach additional responsibilities to an object dynamically. Decorators provide a flexible alternative to subclassing for extending functionality 动态地给一个对象添加一些额外的职责.就增加功能来说, Decorator模式相比生成子类更为灵活. 2.A

设计模式之十二:Proxy(代理)—对象结构型模式

2014-05-29 星期四 21:08:37  Proxy,继续GOF.此模式未按GOF编写. c++中使用StringBuilder 1.Intent Provide a surrogate or placeholder for another object to control access to it. 为其他对象提供一种代理以控制对这个对象的访问. 2.Also Known As 3.Motivation 4.Applicability 在以下情况使用适配模式: ● 创建开销大的对象时

设计模式之十一:Composite(组合)—对象结构型模式

2014-05-28 星期三 21:41:44  Composite,继续GOF. Composite组合模式 1.Intent Compose objects into tree structures to represent part-whole hierarchies. Composite lets clients treat individual objects and compositions of objects uniformly. 将对象组合成树形结构以表示"部分 -整体&quo

Facade(外观)-对象结构型模式

1.意图 为子系统中的一组接口提供一个一致的接口,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. 2.动机 将一个系统划分成若干子系统有利于降低系统的复杂性.一个常见的设计目标是使子系统间的通信和相互依赖达到最小.达到该目标的途径之一是引入一个外观对象,它为子系统提供了一个统一的接口. 3.适用性 当要为一个复杂子系统提供一个简单接口时.子系统往往因为不断演化而变得越来越复杂.大多数模式使用时都会产生更多更小的类.这使得子系统更具可重用性,也更容易对子系统进行定制,但这

Decorator(装饰)-对象结构型模式

1.意图 动态地给一个对象添加一些额外的职责.就增加功能来说,Decorator模式相比生成子类更为灵活. 2.别名 包装器 Wrapper. 3.动机 给某个对象而不是整个类添加一些功能.一个较为灵活的方式时将组件嵌入另一个对象中. 4.适用性 在不影响其它对象的情况下,以动态.透明的方式给单个对象添加职责. 处理那些可以撤销的职责. 当不能采用子类的方法进行扩充时.一种情况是,可能有大量独立的扩展,为支持每一种组合将产生大量的子类,使得子类数目呈爆炸性增长.另一种情况可能是因为类定义被隐藏或

Bridge(桥接)-对象结构型模式

1.意图 将抽象部分与它的实现部分分离,使它们都可以独立地变化. 2.动机 在抽象类与它的实现之间起到桥梁作用,使它们可以独立地变化. 3.适用性 不希望在抽象和它的实现部分之间有一个固定的绑定关系.这种情况可能是因为,在程序运行时刻实现部分可以被选择或切换. 类的抽象以及它的实现部分都应该可以通过生成子类的方式加以扩充.这时桥接模式使你可以对不同的抽象接口和实现部分进行组合,并分别对它们进行扩充. 对一个抽象实现部分的修改的修改不应该对客户产生影响,即客户代码不必要重新编译. 对客户完全隐藏抽

代理(Proxy)——对象结构型模式

代理模式的意图: 为其它对象提供代理,以控制对这个对象的访问.对一个对象进行访问控制的原因是为了我们在确实需要这个对象时才对它进行创建和初始化.有些对象创建的开销非常大,所以我们应该根据需要进行创建.Proxy则可以代替一个对象,并在需要时负责实例化这个对象.就像我们小学的时候总是欺负学习好的同学,让学习好的同学代替我们写作业,要不然我们放学就在路上堵着打他们,学习好的同学就乖乖的帮我们写作业,第二天到学校老师看了作业还表扬我们学习有进步呢.这就是一个很好的代理模式的例子. 代理模式的类图如下: