设计模式

参见

http://zh.wikipedia.org/wiki/%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F_%28%E8%AE%A1%E7%AE%97%E6%9C%BA%29

http://blog.csdn.net/name_110/article/category/911282

http://coolshell.cn/articles/3320.html

 

模式名称描述设计模式》中提及代码大全》中提及[1]
创建型模式
抽象工厂模式

为一个产品族提供了统一的创建接口。当需要这个产品族的某一系列的时候,可以从抽象工厂中选出相应的系列创建一个具体的工厂类。

http://kazge.com/archives/646.html

工厂方法模式

定义一个接口用于创建对象,但是让子类决定初始化哪个类。工厂方法把一个类的初始化下放到子类。

  • java.lang.Proxy#newProxyInstance()
  • java.lang.Object#toString()
生成器模式

将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。

  • java.lang.StringBuilder#append()
  • java.lang.StringBuffer#append()
惰性初始模式

推迟对象的创建、数据的计算等需要耗费较多资源的操作,只有在第一次访问的时候才执行。

对象池模式通过回收利用对象避免获取和释放资源所需的昂贵成本。
原型模式

用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。

  • java.lang.Object#clone()
  • java.lang.Cloneable
单例模式

确保一个类只有一个实例,并提供对该实例的全局访问。

java.lang.Runtime#getRuntime()

多例模式确保一个类只有命名的实例,并提供对这些实例的全局访问。
资源获取为初始化通过绑定到合适对象的生命周期来确保资源被适当地释放。
结构型模式
适配器模式

将某个类的接口转换成客户端期望的另一个接口表示。适配器模式可以消除由于接口不匹配所造成的类兼容性问题。

 Snap1

  • java.util.Arrays#asList()
  • javax.swing.JTable(TableModel)
  • java.io.InputStreamReader(InputStream)
  • java.io.OutputStreamWriter(OutputStream)
  • javax.xml.bind.annotation.adapters.XmlAdapter#marshal()
  • javax.xml.bind.annotation.adapters.XmlAdapter#unmarshal()
桥接模式

将一个抽象与实现解耦,以便两者可以独立的变化。 JDBC

组合模式

把多个对象组成树状结构来表示局部与整体,这样用户可以一样的对待单个对象和对象的组合。

UI组件

 Snap2

  • javax.swing.JComponent#add(Component)
  • java.awt.Container#add(Component)
  • java.util.Map#putAll(Map)
  • java.util.List#addAll(Collection)
  • java.util.Set#addAll(Collection)
修饰模式

向某个对象动态地添加更多的功能。修饰模式是除类继承外另一种扩展功能的方法。

 Snap3

  • java.io.BufferedInputStream(InputStream)
  • java.io.DataInputStream(InputStream)
  • java.io.BufferedOutputStream(OutputStream)
  • java.util.zip.ZipOutputStream(OutputStream)
  • java.util.Collections#checked[List|Map|Set|SortedSet|SortedMap]()
外观模式

为子系统中的一组接口提供一个一致的界面, 外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。

  • java.lang.Class
  • javax.faces.webapp.FacesServlet

我看不出来这两个的facade模式。一个大颗粒的服务函数是否就可以说是门面模式?

享元

通过共享以便有效的支持大量小颗粒对象。

  • Ext.fly
代理

为其他对象提供一个代理以控制对这个对象的访问。

  • RMI
行为型模式
黑板广义的观察者在系统范围内交流信息,允许多位读者和写者。
责任链

为解除请求的发送者和接收者之间耦合,而使多个对象都有机会处理这个请求。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它。

javax.servlet.Filter#doFilter()

命令

将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可取消的操作。

  • java.lang.Runnable
  • javax.swing.Action
解释器

给定一个语言, 定义它的文法的一种表示,并定义一个解释器, 该解释器使用该表示来解释语言中的句子。

java.text.Format

迭代器

提供一种方法顺序访问一个聚合对象中各个元素, 而又不需暴露该对象的内部表示。

  • java.util.Iterator
  • java.util.Enumeration
中介者

包装了一系列对象相互作用的方式,使得这些对象不必相互明显作用,从而使它们可以松散偶合。当某些对象之间的作用发生改变时,不会立即影响其他的一些对象之间的作用,保证这些作用可以彼此独立的变化。

  • java.util.concurrent.ExecutorService#<T> Future<T> submit(Callable<T> task)

让一个复杂的交互变得简单明了,买房者与售房者在中介介入下,是不能直接联系的,双方只会和中介联系。

备忘录

备忘录对象是一个用来存储另外一个对象内部状态的快照的对象。备忘录模式的用意是在不破坏封装的条件下,将一个对象的状态捉住,并外部化,存储起来,从而可以在将来合适的时候把这个对象还原到存储起来的状态。

  • java.io.Serializable
空对象

通过提供默认对象来避免空引用。

  • java.util.Collections#emptyList()
  • java.util.Collections#emptyMap()
  • java.util.Collections#emptySet()
观察者模式

在对象间定义一个一对多的联系性,由此当一个对象改变了状态,所有其他相关的对象会被通知并且自动刷新。

  • java.util.EventListener
规格以布尔形式表示的可重绑定的商业逻辑。
状态

让一个对象在其内部状态改变的时候,其行为也随之改变。状态模式需要对每一个系统可能取得的状态创立一个状态类的子类。当系统的状态变化时,系统便改变所选的子类。

  • java.util.Iterator
策略

定义一个算法的系列,将其各个分装,并且使他们有交互性。策略模式使得算法在用户使用的时候能独立的改变。

  • java.util.Comparator#compare()
模板方法

模板方法模式准备一个抽象类,将部分逻辑以具体方法及具体构造子类的形式实现,然后声明一些抽象方法来迫使子类实现剩余的逻辑。不同的子类可以以不同的方式实现这些抽象方法,从而对剩余的逻辑有不同的实现。先构建一个顶级逻辑框架,而将逻辑的细节留给具体的子类去实现。

jsf中绘制一个组件:

  • renderBegin
  • renderChildren
  • renderEnd
访问者

封装一些施加于某种数据结构元素之上的操作。一旦这些操作需要修改,接受这个操作的数据结构可以保持不变。访问者模式适用于数据结构相对未定的系统,它把数据结构和作用于结构上的操作之间的耦合解脱开,使得操作集合可以相对自由的演化。

访问者对被访问者结构不熟悉,首先需要被访问者允许它来访问(accept),然后由被访问者领着访问者依次访问内部结构,针对每个结构做出不同操作。

并发型模式
主动对象
阻碍
双重检查锁定
守卫
领导者/追随者
监测对象模式
读写锁
调度
线程池模式
线程特定存储
反应器

Continue reading 设计模式

数据集成模型

数据集成是企业集成的一种方式,数据集成有多种模型:

联邦数据库系统(FDBS)

由半自治数据库系统构成,相互之间分享数据,联盟各数据源之间相互提供访问接口,同时联盟数据库系统可以是集中数据库系统或分布式数据库系统及其他联邦式系统。在这种模式下又分为紧耦合和松耦合两种情况,紧耦合提供统一的访问模式,一般是静态的,在增加数据源上比较困难; 而松耦合则不提供统一的接口,但可以通过统一的语言访问数据源,其中核心的是必须解决所有数据源语义上的问题。

中间件模式

通过统一的全局数据模型来访问异构的数据库、遗留系统、Web 资源等。中间件位于异构数据源系统(数据层) 和应用程序(应用层) 之间,向下协调各数据源系统,向上为访问集成数据的应用提供统一数据模式和数据访问的通用接口。各数据源的应用仍然完成它们的任务,中间件系统则主要集中为异构数据源提供一个高层次检索服务。

数据仓库

是在企业管理和决策中面向主题的、集成的、与时间相关的和不可修改的数据集合。其中,数据被归类为广义的、功能上独立的、没有重叠的主题。这几种方法在一定程度上解决了应用之间的数据共享和互通的问题,但也存在以下的异同:联邦数据库系统主要面向多个数据库系统的集成,其中数据源有可能要映射到每一个数据模式,当集成的系统很大时,对实际开发将带来巨大的困难。

 

    中间件模式是目前比较流行的数据集成方法,它通过在中间层提供一个统一的数据逻辑视图来隐藏底层的数据细节,使得用户可以把集成数据源看为一个统一的整体。这种模型下的关键问题是如何构造这个逻辑视图并使得不同数据源之间能映射到这个中间层。

    数据仓库技术则在另外一个层面上表达数据之间的共享,它主要是为了针对企业某个应用领域提出的一种数据集成方法,也就是我们在上面所提到的面向主题并为企业提供数据挖掘和决策支持的系统。

 

共享数据库 数据交换中心 http://www.doc88.com/p-57941106042.html

关键字:一处写,多处用 对原有数据需要修改模型

Snap1

Snap2

Snap3

参见:

http://news.csdn.net/n/20080515/115959.html

http://www.doc88.com/p-57941106042.html

Continue reading 数据集成模型

extjs TreeNode 隐藏展开图标

TreeNode只有expandable这个配置来决定是否显示展开图标,对于要动态设置是否可见的情况,只有通过样式表来实现:

TreeNode.ui 添加class例如:

trrnode.ui.addClass(‘hide-expicon’);

然后再样式表中加入样式:

.hide-expicon .x-tree-ec-icon {
	visibility: hidden;
}

同理,要显示图标则:

trrnode.ui.removeClass(‘hide-expicon’);

Continue reading extjs TreeNode 隐藏展开图标

hashCode 牛角尖

hashCode有什么用?java doc里面说的很清楚了:

  • 1:在 Java 应用程序执行期间,在同一对象上多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是对象上 equals 比较中所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。(同一对象多次调用hashCode应该是相同的。)
  • 2:如果根据 equals(Object) 方法,两个对象是相等的,那么在两个对象中的每个对象上调用 hashCode 方法都必须生成相同的整数结果。 equals比较相同的对象,hashCode应该相同)
  • 3:以下情况 是必需的:如果根据 equals(java.lang.Object) 方法,两个对象不相等,那么在两个对象中的任一对象上调用 hashCode 方法必定会生成不同的整数结果。但是,程序员应该知道,为不相等的对象生成不同整数结果可以提高哈希表的性能。(这句话的意思是不同的对象,他们的hashCode可以是相同的。)

    对于使用hash来判断的集合来说,还是直接看源码比较清楚,以hashmap来说:

    public V put(K key, V value) {
            if (key == null)
                return putForNullKey(value);
            int hash = hash(key.hashCode());
            int i = indexFor(hash, table.length);
            for (Entry<K,V> e = table[i]; e != null; e = e.next) {
                Object k;
                if (

    e.hash == hash && ((k = e.key) == key || key.equals(k))) {
    V oldValue = e.value;
    e.value = value;
    e.recordAccess(this);
    return oldValue;
    }
    }

    modCount++;
    addEntry(hash, key, value, i);
    return null;
    }

    public V get(Object key) {
            if (key == null)
                return getForNullKey();
            int hash = hash(key.hashCode());
            for (Entry<K,V> e = table[indexFor(hash, table.length)];
                 e != null;
                 e = e.next) {
                Object k;
                if (

    e.hash == hash && ((k = e.key) == key || key.equals(k)))
    return e.value;
    }
    return null;
    }

     

    看清楚了,是先比较hashcode再比较equal,当然,一旦hashcode不同,短路后那么equal就不会判断了。

    这就揭开了我的牛角尖,不同类型的对象hashcode相同怎么办?

    不同类型对象即使hashcode存在偶然相同的可能,equal理论上是应该不同的。在实现hashcode时,只要考虑同一类型中不同即可,不必要做到UUID的级别!

    那么就别把hashcode当UUID使用了!

    Continue reading hashCode 牛角尖

  • Extjs XTemplate IE 下问题?

    今天碰到个古怪的问题,使用Extjs的XTemplate,在FF下很好,在IE下就不行。

    我的做法是将模板放在html里面,再通过innerHTML得到这个模板来生成XTemplate。本来是个偷懒的办法,但是IE得到的innerHTML将标签全部大写了!造成<tpl for=”.”> 变成大写了。<TPL for=”.”>。估计问题就出在这里,extjs又区分了大小写,所以不解释!偷懒有代价!!

    Continue reading Extjs XTemplate IE 下问题?

    xerces dtd解析验证问题

    xerces解析xml文档默认会验证dtd,这个过程需要网络连通,而且可能非常耗时。同时使用xerces的包又是很多的,这个设计真是麻烦!

    对于dom4j,可以这样解决:

    SAXReader reader = new SAXReader();
    	
    			reader.setValidation(false);
    			try
    			{
    				reader.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd", false);
    			}
    			catch (SAXException e)
    			{
    				// do nothing
    			}
    		

    对于javax.xml:

    javax.xml.parsers.DocumentBuilderFactory documentBuilderFactory = javax.xml.parsers.DocumentBuilderFactory
    					.newInstance();
    			documentBuilderFactory.setValidating(false);
    			javax.xml.parsers.DocumentBuilder documentBuilder = documentBuilderFactory.newDocumentBuilder();
    			documentBuilder.setEntityResolver(new EntityResolver() {
    				public InputSource resolveEntity(String publicId, String systemId) throws SAXException, IOException
    				{
    					return new org.xml.sax.InputSource(new java.io.StringReader(""));
    				}
    			});

    其他类似,设置自己的EntryResolver即可。

    Continue reading xerces dtd解析验证问题

    Servlet Api 和 JavaServerPage Version

     

    Servlet API history
    Servlet API versionReleasedPlatformImportant Changes
    Servlet 3.0December 2009JavaEE 6, JavaSE 6Pluggability, Ease of development, Async Servlet, Security, File Uploading
    Servlet 2.5
    Jsp2.1
    September 2005JavaEE 5, JavaSE 5Requires JavaSE 5, supports annotation
    Servlet 2.4
    Jsp2.0
    November 2003J2EE 1.4, J2SE 1.3web.xml uses XML Schema
    Servlet 2.3 Jsp1.2August 2001J2EE 1.3, J2SE 1.2Addition of Filter
    Servlet 2.2August 1999J2EE 1.2, J2SE 1.2Becomes part of J2EE, introduced independent web applications in .war files
    Servlet 2.1November 1998UnspecifiedFirst official specification, added RequestDispatcher, ServletContext
    Servlet 2.0 JDK 1.1Part of Java Servlet Development Kit 2.0
    Servlet 1.0June 1997  

    更详细的见wiki:

    http://en.wikipedia.org/wiki/Java_Servlet

    http://en.wikipedia.org/wiki/JavaServer_Pages

    Tomcat 5.5实现 Servlet2.4和Jsp2.0

    Tomcat 6实现 Servlet2.5和Jsp2.1

    Continue reading Servlet Api 和 JavaServerPage Version

    Pagination


    Total views.

    © 2013 - 2019. All rights reserved.

    Powered by Hydejack v6.6.1