本文介绍了7样的结构模型中的其余2种:轻量级、代理模式。

一、享元模式FlyWeight

享元模式比較简单且重要,在非常多场合都被用到。仅仅只是封装起来了用户看不到。其概念:运用共享内存技术最大限度的支持大量细粒度的对象。

这个概念给的有些抽象,说白了就是假设内存中存在某个对象A。假设再次须要使用对象A的时候假设内存中有A这个对象就直接使用它,不要再次new了。假设没有,则又一次new一个。基于这个特点,享元模式使用时通常会给待訪问对象传递一个Tag,用来标识这个对象,并且要同一时候使用抽象工厂的方法进行訪问。

有点相似单例模式,仅仅只是单例内存中仅仅有一个对象,而享元模式是确保同样Tag的对象有且仅仅有一个。

1.Flyweight 描写叙述一个接口,通过这个接口flyweight能够接受并作用于外部状态。

public interface Flyweight {
    void action(int arg);
}

2.ConcreteFlyweight实现Flyweight接口,并为内部状态(假设有的话)添加存储空间。ConcreteFlyweight对象必须是可共享的。

它所存储的状态必须是内部的;即,它必须独立于ConcreteFlyweight对象的场景。

public class FlyweightImpl implements Flyweight {

public void action(int arg) {
        // T*DO Auto-genera*ed method stub
        System.out.println(*參数值: " + arg);
    }
}

3. FlyweightFactory      创建并管理flyweight对象。确保合理地共享flyweight。当用户请求一个flyweight时,flyweightFactory对象提供一个已创建的实例或者创建一个(假设不存在的话)。

public class FlyweightFactory {

private static Map flyweights = new HashMap();
    
    public FlyweightFactory(String arg) {
        flyweights.put(arg, new FlyweightImpl());
    }
    
    public static Flyweight getFly*eight(String key) {
        if (flyweights.get(key) == null) {
            flyweights.put(key, new FlyweightImpl());
        }
        return flyweights.get(key);
    }
    
    public static int getSize() {
        return flyweights.size();
    }
}

測试代码:

public class Test {

public static void main(String[] args) {
        // TODO Auto-generated method stub
        Flyweight fly1 = FlyweightFactory.getFlyweight("a");
        fly1.action(1);
        
        Flyweight fly1 = FlyweightFactory.getFlyweight("a");
        System.out.println(fly1 == fly2);
        
        Flyweight fly3 = FlyweightFactory.getFlyweight("b");
        fly3.action(2);
        
        Flyweight fly4 = FlyweightFactory.getFlyweight("c");
        fly4.action(3);
        
        Flyweight fly5 = FlyweightFactory.getFlyweight("d");
        fly4.action(4);
        
        System.out.println(FlyweightFactory.getSize());
    }
}

适用性:

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

2.全然因为使用大量的对象,造成非常大的存储开销。

3.对象*大多数状态都可变为外部状态。
4.假设删除对象的外部状态,那么能够*相对较少的共享对象代替非常多组对象。
5.应用程序不依赖于对象标识。因为Flyweight对象能够被共享,对于*念上明显有别的对象。标识測试将返回真值。

能够看到前面有篇博文讲Fragment的使用,里面有好几个Fragment就是用的享元模式。另外。像线程池等也是用的享元模式。

在listview的适配器刷新为了更加流畅不必每次都new。对convertView的处理也是享元模式。

也可參考链接:http://blog.csdn.net/jason0539/article/details/22908915

二、代理模式Proxy

为其它对象提供一种代理以控制对这个对象的訪问。

事实上这个思想非常easy,如银行的快捷支付就是一个典型的样例。购物时本来要从银行里拿钱。走银行的通道,因为你的钱本来就在银行放着。支付宝来了,说不用。我先替你垫着,然后支付宝给你出钱,过后支付宝拿着单子找银行要钱。这就是代理模式。

1.Subject 主题,是RealSubject和Proxy共同调用的接口,比方上面提到的付钱。这是约束支付宝和银行的共同接口。

public interface Object {
    void action();
}

2.RealSubject 定义Proxy所代表的实体。这里就像“银行通道”。

public class ObjectImpl implements Object {

public void action() {
        System.out.println("========");
        System.out.println("========");
        System.out.pr*ntln("这是被代理的类");
        System.out.println("========");
        System.out.println("========");
    }
}

3.Proxy代理。相应上面的支付宝

public class ProxyObject implements Object {

Object obj;
    
    public ProxyObject() {
        System.out.println("这是代理类");
        obj = new ObjectImpl();
    }
    
    public void action() {
        System.out.println("代理開始");
        obj.action();
        System.out.println("代理结束");
    }
}

測试代码:

public class Test {

public static void main() {
    Object obj = new ProxyObject();
        obj.action();
    }
}

从上面能够看到,代理模式和适配器模式非常之像。都是在一个类里维持了还有一个类的抽象接口,然后实例化这个接口去做一些操作。

但代理模式跟适配器模式最大的差别是:代理类和被代理的对象类实现了共同的接口。如同支付宝和银行都提供取钱这个共同的操作。

但,适配器模式不同。适配器类和要适配的类相应的接口是不一样的。这本身就是适配的目的所在,将原有类的一个接口适配成另外一个接口供外围调用。举个样例,我要想送礼,买了一个2万的奢侈品,这个接口是“买东西”。然后我把东西给某高官送过去了,高官当然不会要嘛,就拿着东西去商场退货。这个接口是“退货”。

最后嘛,钱就到高官手里了。这就是适配器模式,“买东西”和“退货”属于两个不同的接口。

至于外观模式,举个样例,要打造一部手机,须要生产、研发、销售三大环节。每个环节都有大量的步骤,比方生产得採购原材料吧,採购时是不是先紧着亲戚的厂来点回扣吧,东西买回来要组装生产,扣点生产线上小娄娄的钱。偷个工减点料,一倒手又是银子吧!但给大领导汇报你这么整仅仅有找死,于是将大量步骤封装再封装,对大老板说这个生产嘛。

。研发嘛。。

。销售嘛,三个接口。这就是外观模式。

至此5种创建型模式、7种结构型模式已交代完成,明天開始11种行为型模式。

代理模式亦可參考链接:链接1  链接2

版权声明:本文博客原创文章。博客,未经同意,不得转载。

Java经典23结构模型的设计模式(三)------附加代理模式、适配器型号、Facade模式的差异的更多相关文章

  1. Java经典23种设计模式之行为型模式(三)

    本文接着介绍11种行为型模式里的备忘录模式.观察者模式.状态模式. 一.备忘录模式 在不破坏封装性的前提下,捕获一个对象的内部状态.并在该对象之外保存这个状态.这样以后就能够将该对象恢复到原先保存的状 ...

  2. Java经典23种设计模式之创造型模式(一)

    设计模式被称为程序猿的内功,之前零零散散的看过一大部分,但自己么有总结过.故此次在这里总结下.值得一提的是,设计模式并不是Java所特有.由于一直搞Android.这里就用Java为载体.最经典的设计 ...

  3. Java经典23种设计模式之行为型模式(二)

    本文接着介绍行为型模式里的解释器模式.迭代器模式.中介者模式. 一.解释器模式Interpret 给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言的中的句子. 1 ...

  4. Java经典23种设计模式之结构型模式(一)

    结构型模式包含7种:适配器模式.桥接模式.组合模式.装饰模式.外观模式.享元模式.代理模式. 本文主要介绍适配器模式和桥接模式. 一.适配器模式(Adapter) 适配器模式事实上非常easy.就像手 ...

  5. Java开发中常用的设计模式(三)---建造者模式

    一. 模式结构 建造者模式主要包含四个角色: Product:产品角色. Builder:抽象建造者.它声明为创建一个Product对象的各个部件指定的抽象接口. ConcreteBuilder:具体 ...

  6. Java经典23创意模式设计模式(两)

    本文介绍5其余两种创意模式:模型构建器(Builder).原型模型(PROTOTYPE). 一.建造者模式(别名:生成者模式) 将复杂对象的构建和它的表示分离,使得相同的构建过程能够创建不同的表示. ...

  7. Java设计模式(三)原型模型 适配器型号

    (五岁以下儿童)原型模型 Prototype 样机模型旨在复制一个现有对象来创建新对象.而不是通过的方式的实例.原型模式须要实现 Cloneable 接口.覆写clone方法,复制分为浅复制.深复制. ...

  8. Java模式(适配器型号)

    今天阅读Java该适配器模式,这里有一个小的总结和下谈感受.对于将来使用. 首先.让我们有关适配器先说说. 适应是“来源”至“目标”适应.其中连接这两个的关系是适配器.它负责“源”过度到“目标”. 举 ...

  9. Java中23种经典设计模式详解

    Java中23种设计模式目录1. 设计模式 31.1 创建型模式 41.1.1 工厂方法 41.1.2 抽象工厂 61.1.3 建造者模式 101.1.4 单态模式 131.1.5 原型模式 151. ...

随机推荐

  1. 深入理解Tomcat系列之二:源码调试环境搭建(转)

    前言 最近对Tomcat的源码比较感兴趣,于是折腾了一番.要调试源码首先需要搭建环境,由于参考了几篇帖子发现都不怎么靠谱,最后还是折腾出来了,然而却花了足足一天的时间去搭建这个环境.发现都不是帖子的问 ...

  2. ArrayBlockingQueue和LinkedBlockingQueue的区别

    ArrayBlockingQueue和LinkedBlockingQueue的区别,得出结论如下: 1. 队列中锁的实现不同 ArrayBlockingQueue实现的队列中的锁是没有分离的,即生产和 ...

  3. Django之逆向解析url

    Django中提供了一个关于URL的映射的解决方案,你可以做两个方向的使用: 1.有客户端的浏览器发起一个url请求,Django根据URL解析,把url中的参数捕获,调用相应的试图, 获取相应的数据 ...

  4. ORA-00210 ORA-15001 ORA-15055 ORA-01031: insufficient privileges

    ORA-00210: cannot open the specified control file ORA-00202: control file: '+DATA/posdb/con ...

  5. poj1155(树形dp)

    题目链接:http://poj.org/problem?id=1155 题意:电视台要直播一场比赛,电视网络刚好形成了一棵树,其中有M个为客户端,其他的为中转站,其中中转站与中转站以及中转站与客户端之 ...

  6. 新 Netflix 开源门户

    Netflix 开源改革计划:新 Netflix 开源门户 http://www.oschina.net/news/67555/evolution-of-open-source-at-netflix ...

  7. 使用OGG"Loading data from file to Replicat"的方法应该注意的问题:replicat进程是前台进程

    使用OGG的 "Loading data from file to Replicat"的方法应该注意的问题:replicat进程是前台进程 因此.最好是在vncserver中调用该 ...

  8. C++ 在字符串中插入子串+推断字符串是否由空格组成

    // Example3.cpp : 定义控制台应用程序的入口点. #include "StdAfx.h" #include <string> #include < ...

  9. html 跳转页面,同时跳转到一个指定的位置

    比如我现在 a.html 的时候,我想跳转到 b.html ,并且是 b.html 的某一个位置,用 <a href=>, a.html里: <a href="b.html ...

  10. 安装pygame

    pygame的安装 我们首先要去到:http://www.pygame.org/download.shtml 下载我们所需要的软件包: 我选择的是:pygame-1.9.2a0.win32-py3.2 ...