设计模式面试题

Birdge 桥接模式:java

这个模式将抽象和抽象操做的实现进行了解耦,这样使得抽象和实现能够独立地变化。web

GOF在提出桥梁模式的时候指出,桥梁模式的用意是"将抽象化(Abstraction)与实现化(Implementation)脱耦,使得两者能够独立地变化"。这句话有三个关键词,也就是抽象化、实现化和脱耦。算法

在Java应用中,对于桥接模式有一个很是典型的例子,就是应用程序使用JDBC驱动程序进行开发的方式。所谓驱动程序,指的是按照预先约定好的接口来操做计算机系统或者是外围设备的程序。sql

 

Adapter 适配器模式:缓存

用来把一个接口转化成另外一个接口。使得本来因为接口不兼容而不能一块儿工做的那些类能够在一块儿工做。app

java.util.Arrays#asList()框架

java.io.InputStreamReader(InputStream)webapp

java.io.OutputStreamWriter(OutputStream)ide

 

Composite 组合模式:ui

又叫作部分-总体模式,使得客户端看来单个对象和对象的组合是同等的。换句话说,某个类型的方法同时也接受自身类型做为参数。

avax.swing.JComponent#add(Component)

java.util.Map#putAll(Map)

java.util.List#addAll(Collection)

java.util.Set#addAll(Collection)

 

装饰者模式:

动态的给一个对象附加额外的功能,这也是子类的一种替代方式。能够看到,在建立一个类型的时候,同时也传入同一类型的对象。这在JDK里随处可见,你会发现它无处不在,因此下面这个列表只是一小部分。

java.io.BufferedInputStream(InputStream)

java.io.DataInputStream(InputStream)

java.io.BufferedOutputStream(OutputStream)

java.util.zip.ZipOutputStream(OutputStream)

java.util.Collections#checkedList|Map|Set|SortedSet|SortedMap

 

Facade 门面模式,即外观模式:

给一组组件,接口,抽象,或者子系统提供一个简单的接口。

java.lang.Class

javax.faces.webapp.FacesServlet

 

Flyweight 享元模式:

使用缓存来加速大量小对象的访问时间。

java.lang.Integer#valueOf(int)

java.lang.Boolean#valueOf(boolean)

java.lang.Byte#valueOf(byte)

java.lang.Character#valueOf(char)

 

Proxy 代理模式:

代理模式是用一个简单的对象来代替一个复杂的或者建立耗时的对象。

java.lang.reflect.Proxy

RMI

 

Abstract Factory 抽象工厂模式:

抽象工厂模式提供了一个协议来生成一系列的相关或者独立的对象,而不用指定具体对象的类型。它使得应用程序可以和使用的框架的具体实现进行解耦。这在JDK或者许多框架好比Spring中都随处可见。它们也很容易识别,一个建立新对象的方法,返回的倒是接口或者抽象类的,就是抽象工厂模式了。

java.util.Calendar#getInstance()

java.util.Arrays#asList()

java.util.ResourceBundle#getBundle()

java.sql.DriverManager#getConnection()

java.sql.Connection#createStatement()

java.sql.Statement#executeQuery()

java.text.NumberFormat#getInstance()

javax.xml.transform.TransformerFactory#newInstance()

 

 

抽象工厂模式

抽象工厂模式提供了一个协议来生成一系列的相关或者独立的对象,而不用指定具体对象的类型。它使得应用程序可以和使用的框架的具体实现进行解耦。这在JDK或者许多框架好比Spring中都随处可见。它们也很容易识别,一个建立新对象的方法,返回的倒是接口或者抽象类的,就是抽象工厂模式了。

java.util.Calendar#getInstance()

java.util.Arrays#asList()

java.util.ResourceBundle#getBundle()

java.sql.DriverManager#getConnection()

java.sql.Connection#createStatement()

java.sql.Statement#executeQuery()

java.text.NumberFormat#getInstance()

javax.xml.transform.TransformerFactory#newInstance()

 

Builder 建造者模式:

定义了一个新的类来构建另外一个类的实例,以简化复杂对象的建立。建造模式一般也使用方法连接来实现。

java.lang.StringBuilder#append()

java.lang.StringBuffer#append()

java.sql.PreparedStatement

javax.swing.GroupLayout.Group#addComponent()

 

工厂方法:

就是一个返回具体对象的方法。

java.lang.Proxy#newProxyInstance()

java.lang.Object#toString()

java.lang.Class#newInstance()

java.lang.reflect.Array#newInstance()

java.lang.reflect.Constructor#newInstance()

java.lang.Boolean#valueOf(String)

java.lang.Class#forName()

 

原型模式

使得类的实例可以生成自身的拷贝。若是建立一个对象的实例很是复杂且耗时时,就可使用这种模式,而不从新建立一个新的实例,你能够拷贝一个对象并直接修改它。

java.lang.Object#clone()

java.lang.Cloneable

 

单例模式

用来确保类只有一个实例。Joshua Bloch在Effetive Java中建议到,还有一种方法就是使用枚举。

java.lang.Runtime#getRuntime()

java.awt.Toolkit#getDefaultToolkit()

java.awt.GraphicsEnvironment#getLocalGraphicsEnvironment()

java.awt.Desktop#getDesktop()

 

 

责任链模式

经过把请求从一个对象传递到链条中下一个对象的方式,直到请求被处理完毕,以实现对象间的解耦。

 

java.util.logging.Logger#log()

javax.servlet.Filter#doFilter()

命令模式

将操做封装到对象内,以便存储,传递和返回。

 

java.lang.Runnable

javax.swing.Action

解释器模式

这个模式一般定义了一个语言的语法,而后解析相应语法的语句。

 

java.util.Pattern

java.text.Normalizer

java.text.Format

迭代器模式

提供一个一致的方法来顺序访问集合中的对象,这个方法与底层的集合的具体实现无关。

 

java.util.Iterator

java.util.Enumeration

中介者模式

经过使用一个中间对象来进行消息分发以及减小类之间的直接依赖。

 

java.util.Timer

java.util.concurrent.Executor#execute()

java.util.concurrent.ExecutorService#submit()

java.lang.reflect.Method#invoke()

备忘录模式

生成对象状态的一个快照,以便对象能够恢复原始状态而不用暴露自身的内容。Date对象经过自身内部的一个long值来实现备忘录模式。

 

java.util.Date

java.io.Serializable

空对象模式

这个模式经过一个无心义的对象来代替没有对象这个状态。它使得你不用额外对空对象进行处理。

 

java.util.Collections#emptyList()

java.util.Collections#emptyMap()

java.util.Collections#emptySet()

观察者模式

它使得一个对象能够灵活的将消息发送给感兴趣的对象。

 

java.util.EventListener

javax.servlet.http.HttpSessionBindingListener

javax.servlet.http.HttpSessionAttributeListener

javax.faces.event.PhaseListener

状态模式

经过改变对象内部的状态,使得你能够在运行时动态改变一个对象的行为。

 

java.util.Iterator

javax.faces.lifecycle.LifeCycle#execute()

策略模式

使用这个模式来将一组算法封装成一系列对象。经过传递这些对象能够灵活的改变程序的功能。

 

java.util.Comparator#compare()

javax.servlet.http.HttpServlet

javax.servlet.Filter#doFilter()

模板方法模式

让子类能够重写方法的一部分,而不是整个重写,你能够控制子类须要重写那些操做。

 

java.util.Collections#sort()

java.io.InputStream#skip()

java.io.InputStream#read()

java.util.AbstractList#indexOf()

访问者模式

提供一个方便的可维护的方式来操做一组对象。它使得你在不改变操做的对象前提下,能够修改或者扩展对象的行为。

 

javax.lang.model.element.Element and javax.lang.model.element.ElementVisitor

javax.lang.model.type.TypeMirror and javax.lang.model.type.TypeVisitor

相关文章
相关标签/搜索