`

享元模式——Flyweight

 
阅读更多

 

 享元模式——Flyweight

1. 概念

 

    享元模式 (Flyweight ,轻量级选手 ) 就是利用可共享对象的池。因而,通常用到 Factory ,称为 Flyweight Factory 享元工厂 (Sam)

    将对象定义为不可变 (immutable) 的是避免客户代码之间相互影响最简单方法, Java 语言中最常见的不可变对象 String 类对象 (public final class String{...}) 。在 Oozinoz 公司的例子中,化学物 Substance_Before 类对象中包含两种类型的属性——可变部分 ( 重量等 )& 不可变部分 ( 原子量,名称,化学式 ) ,我们将不变部分抽象 为另一个类 Chemical ,从而将 Substance_Before 改造为 Substance_After 。这样,当系统中 Substance 对象很多时,不必为每个对象维护众多的不变部分信息 ( 可以共享少量 Chemical 实例 )

    因此,享元模式使用 的过程实际上是个源码重构 的过程,可以在最终的代码中看不出享元的痕迹(例如 BorderFactory 类),看起来很像 Factory 模式。

    然而,将对象的不可变部分提取出来仅是使用享元模式的前面一半工作。后一半工作是创建一个享元工厂 Chemical_Factory ,用于实例化享元,并组织共享享元的客户代码。另外,为了保证客户代码使用享元工厂获取享元,而非自己创建,可以限定 Chemical 的可见性: Chemical 作为 Chemical Factory 的内部类

 

举例: BorderFactory 是典型的 Flyweight Factory

javax.swing.BorderFactory - Factory class for vending(vt. vi. 出售,贩卖 ) standard Border objects. Wherever possible, this factory will hand out( 分发;施舍;把…拿出来 ) references to shared Border instances.

 

javax.swing.Border - Provides classes and interfaces for drawing specialized borders around a Swing component.

 

public class BorderFactory{

    final static Border emptyBorder=new EmptyBorder(0,0,0,0);

    public static Border createEmptyBorder(){ return emptyBorder;}

}

 

2. 享元模式使用:

    Substance_Before 重构为 Substance_After&Chemical

    但为了保证客户代码用享元工厂获取享元对象,在 Substance_After 中编写 ChemicalImpl( 实现 Chemical 接口,这样方便从 Substance_After 中引用到接口 )

 

 

 

public class Substance_Before {
    /*
      * 可变部分
      */

    private double grams ;    /* 重量 i.e. 75g*/ 

    /*
      * 不可变部分
      */
    private String name ; /* 化学名称 i.e. Saltpeter */
    private String symbol ;   /* 化学式 i.e. KNO3*/
    private double atomicWeight ;    /* 原子量 i.e. 101*/   

    public double getMoles (){
       return grams / atomicWeight ;
    }
} 
 

 

*****************************************************************

使用享元模式重构后:

 

public class Substance_After {
    /*
      * 可变部分
      */
    private double grams ;
   
    /*
      * 不可变部分
      * 抽象为类 Chemical 对象 !
      * 好处:当 Substance_After 对象很多时,可以引用少量的
      * Chemical 实例;而不必自身维护大量不变部分信息。
      */
    private Chemical chemical ; /* 使用接口来访问不变对象 */

    public double getMoles(){
       return grams / chemical .getAtomicWeight();
    }
} 
 

 

public class Chemical_Factory {
    private static Map chemicals = new HashMap ();

    static {
       chemicals .put( "carbon" , new ChemicalImpl( "Carbon" , "C" ,22)) ;
       chemicals .put( "sulfur" , new ChemicalImpl( "Sulfur" , "S" ,32)) ;
       chemicals .put( "saltpeter" , new ChemicalImpl( "Saltpeter" , "KNO3" ,101)) ;
    }

    /*
     * 1. static 修饰类时只能用于内部类,不能用于普通类
     * 2. static 内部类中的 static 成员(类成员)和对象成员都作为对象成员使用 !
      */
    private static class ChemicalImpl implements Chemical {
       private String name ; /* 化学名称 i.e. Saltpeter */
       private String symbol ;   /* 化学式 i.e. KNO3*/
       private double atomicWeight ;    /* 原子量 i.e. 101*/
      
       private ChemicalImpl(String name,String symbol, double atomicWeight){
           this . name =name;
           this . symbol =symbol;
           this . atomicWeight =atomicWeight;
       }
       public double getAtomicWeight() {
           return atomicWeight ;
       }
       public String getName() {
           return name ;
       }
       public String getSymbol() {
           return symbol ;
       }
    }
   
    public static Chemical getChemical(String name){
       return (Chemical) chemicals .get(name.toLowerCase());
    }
} 
 
public interface Chemical
{
    String getName();
    String getSymbol();
    double getAtomicWeight();
}
 

 

采用享元模式后,客户端调用方法:

public class Main {
	public static void main(String[] args) {
		Substance_After s1=new Substance_After(75,Chemical_Factory.getChemical("SALTPETER"));
		Substance_After s2=new Substance_After(150,Chemical_Factory.getChemical("saltpeter"));
		
		System.out.println(s1.getMoles());
		System.out.println(s2.getMoles());
	}
}
 
分享到:
评论

相关推荐

    享元模式的分析以及实际应用.docx

    1. **抽象享元(Flyweight)**:这是享元模式的接口,定义了所有享元对象公共的行为。 2. **具体享元(Concrete Flyweight)**:实现了抽象享元接口,提供了具体的业务逻辑。这些对象是可以共享的,并且通常存储在一...

    设计模式之轻量级Flyweight

    本文将深入探讨“轻量级”设计模式之一——Flyweight(享元)模式,它是如何在减少内存消耗的同时提高系统性能的。 Flyweight模式的核心思想是共享对象,通过复用大量相似对象来减少内存占用。这种模式通常在处理...

    Python设计模式之享元模式原理与用法实例分析

    设计模式——享元模式 享元模式(Flyweight Pattern):运用共享技术有效地支持大量细粒度的对象 对一个类进行的实例,只在第一次使用时建立,其他时候是用同一个实例,减少内存的开销 """ # 抽象网站类 class Web

    设计模式代码——c#

    11. 享元模式(Flyweight Pattern) 12. 代理模式(Proxy Pattern) 行为型 13. 模板方法(Template Method) 14. 命令模式(Command Pattern) 15. 迭代器模式(Iterator Pattern) 16. 观察者模式(Observer Pattern...

    设计模式

    在本文中,我们将深入探讨一种重要的设计模式——享元模式(Flyweight Pattern)。 享元模式是一种结构型设计模式,它的主要目标是有效地支持大量细粒度的对象,通过共享已经存在的对象来减少内存消耗。在面向对象...

    设计模式可复用面向对象软件的基础.zip

    4.6 Flyweight(享元)—对象结构型 模式 128 4.7 Proxy(代理)—对象结构型 模式 137 4.8 结构型模式的讨论 144 4.8.1 Adapter与Bridge 144 4.8.2 Composite、Decorator与Proxy 145 第5章 行为模式 147 5.1 CHAIN ...

    管理系统javasal源码-Design-Patterns-Demo:超全的设计模式——理论+实现demo

    管理系统java sal源码 [toc] 设计模式 源码地址: 博客地址: 分类 序号 模式 & ...创建型模式:这些设计模式提供了一种在创建对象的同时隐藏创建逻辑...Pattern)享元模式(Flyweight Pattern)代理模式(Proxy Pattern)

    《java设计模式》课后习题模拟试题解答——刘伟.zip

    2. **结构型模式**:如适配器(Adapter)、装饰器(Decorator)、代理(Proxy)、桥接(Bridge)、组合(Composite)、外观(Facade)和享元(Flyweight)。这些模式处理对象的组合和关系,提供更好的结构和接口,...

    X-gen PPT下载——《研磨设计模式》 实战

    2. **结构型模式**:如适配器模式(Adapter)、装饰器模式(Decorator)、代理模式(Proxy)、桥接模式(Bridge)、组合模式(Composite)、外观模式(Facade)和享元模式(Flyweight)。这些模式处理对象之间的关系...

    design-pattern-java.pdf

    扩展系统功能——装饰模式(四) 外观模式-Facade Pattern 深入浅出外观模式(一) 深入浅出外观模式(二) 深入浅出外观模式(三) 享元模式-Flyweight Pattern 实现对象的复用——享元模式(一) 实现对象的复用...

    设计模式-可复用面向对象软件的基础

    包括适配器模式(Adapter)、桥接模式(Bridge)、装饰器模式(Decorator)、组合模式(Composite)、外观模式(Facade)、享元模式(Flyweight)和代理模式(Proxy)。它们帮助我们在不同的对象之间建立关系,实现...

    PHP设计模式概论【概念、分类、原则等】

    常见的结构型模式有适配器模式(Adapter)、装饰器模式(Decorator)、代理模式(Proxy)、桥接模式(Bridge)、组合模式(Composite)、外观模式(Facade)和享元模式(Flyweight)。 3. 行为型模式:这一类模式...

    DesignPatternsDemo:Java 中的设计模式——简短示例

    10. 享元模式(Flyweight Pattern): 享元模式有效地共享对象,减少内存使用。例如,在文本编辑器中,可以使用享元模式只存储一个字符对象,但能表示文本中的多次出现。 以上就是Java设计模式的一些核心概念和应用...

    设计模式PPT---25种设计模式详解

    6. 享元模式(Flyweight):为了减少大量相似对象的创建,共享内存中的对象。 7. 代理模式(Proxy):为其他对象提供一种代理以控制对这个对象的访问。 行为型模式则关注对象之间的交互和责任分配,包括: 1. 责任...

    JAVA设计模式(中文).chm

    结构型模式处理对象组合和类的结构,例如适配器模式(Adapter)、装饰器模式(Decorator)、代理模式(Proxy)、桥接模式(Bridge)、组合模式(Composite)、外观模式(Facade)和享元模式(Flyweight)。...

    JAVA设计模式.影印版

    **Java设计模式——深入解析与应用** 在编程领域,设计模式是解决常见问题的经验总结,是一种通用、可重用的解决方案。Java设计模式是面向对象编程中的精华,它为开发者提供了一套标准的方法来处理软件设计中的常见...

    设计模式 让你轻松理解设计模式,提高开发效率

    享元模式(Flyweight) 享元模式是一种结构型设计模式,它用于减少创建大量相同或相似对象时的内存开销。该模式通过共享技术来有效地支持大量细粒度的对象。文章中通过“MM打招呼”的例子,展示了如何通过享元模式...

    JAVA设计模式--入门

    5. 享元模式(Flyweight):通过共享技术,有效地支持大量细粒度的对象。 6. 装饰模式(Decorator):动态地给对象添加新的职责,装饰者和被装饰对象有相同的接口。 **行为型设计模式** 1. 责任链模式(Chain of ...

    java高手真经 (UML建模+设计模式+面向服务架构) 卷6

    pattern/src/structure/facade //12.4外观模式 pattern/src/structure/bridge //12.5桥接模式 pattern/src/structure/composite //12.6组合模式 pattern/src/structure/flyweight //12.7享元模式 pattern/src/...

Global site tag (gtag.js) - Google Analytics