- 浏览: 560891 次
博客专栏
-
开源视频会议bigblue...
浏览量:87009
文章分类
最新评论
-
qq632680822:
你好,请问第八条sql优化最佳实践中from 子句--执行顺序 ...
高效sql性能优化极简教程 -
tan_zheng:
大神 ,为什么我没有 bbb-conf --setup-dev ...
开源视频会议bigbluebutton开发(4)——构建开发环境,客户端开发 -
lixuejian:
6666666
过年了,让你的服务器提高警惕! -
tonney:
直播直播直播
直播技术视频教程分享 -
GYHui881204:
直播
直播技术视频教程分享
Structural(结构模式)
Adapter:
把一个接口或是类变成另外一种。
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()
Bridge:
把抽象和实现解藕,于是接口和实现可在完全独立开来。
AWT (提供了抽象层映射于实际的操作系统)
JDBC
Composite:
让使用者把单独的对象和组合对象混用。
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)
Decorator:
为一个对象动态的加上一系列的动作,而不需要因为这些动作的不同而产生大量的继承类。这个模式在JDK中几乎无处不在,所以,下面的列表只是一些典型的。
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]()
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
Creational(创建模式)
Abstract factory:
创建一组有关联的对象实例。这个模式在JDK中也是相当的常见,还有很多的framework例如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:
主要用来简化一个复杂的对象的创建。这个模式也可以用来实现一个 Fluent Interface。
java.lang.StringBuilder#append()
java.lang.StringBuffer#append()
java.sql.PreparedStatement
javax.swing.GroupLayout.Group#addComponent()
Factory:
简单来说,按照需求返回一个类型的实例。
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()
Prototype:
使用自己的实例创建另一个实例。有时候,创建一个实例然后再把已有实例的值拷贝过去,是一个很复杂的动作。所以,使用这个模式可以避免这样的复杂性。
java.lang.Object#clone()
java.lang.Cloneable
Singleton:
只允许一个实例。在 Effective Java中建议使用Emun.
java.lang.Runtime#getRuntime()
java.awt.Toolkit#getDefaultToolkit()
java.awt.GraphicsEnvironment#getLocalGraphicsEnvironment()
java.awt.Desktop#getDesktop()
Behavioral(行为模式)
Chain of responsibility:
把一个对象在一个链接传递直到被处理。在这个链上的所有的对象有相同的接口(抽象类)但却有不同的实现。
java.util.logging.Logger#log()
javax.servlet.Filter#doFilter()
Command:
把一个或一些命令封装到一个对象中。
java.lang.Runnable
javax.swing.Action
Interpreter:
一个语法解释器的模式。
java.util.Pattern
java.text.Normalizer
java.text.Format
Iterator:
提供一种一致的方法来顺序遍历一个容器中的所有元素。
java.util.Iterator
java.util.Enumeration
Mediator:
用来减少对象单的直接通讯的依赖关系。使用一个中间类来管理消息的方向。
java.util.Timer
java.util.concurrent.Executor#execute()
java.util.concurrent.ExecutorService#submit()
java.lang.reflect.Method#invoke()
Memento:
给一个对象的状态做一个快照。Date类在内部使用了一个long型来做这个快照。
java.util.Date
java.io.Serializable
Null Object:
这个模式用来解决如果一个Collection中没有元素的情况。
java.util.Collections#emptyList()
java.util.Collections#emptyMap()
java.util.Collections#emptySet()
Observer:
允许一个对象向所有的侦听的对象广播自己的消息或事件。
java.util.EventListener
javax.servlet.http.HttpSessionBindingListener
javax.servlet.http.HttpSessionAttributeListener
javax.faces.event.PhaseListener
State:
这个模式允许你可以在运行时很容易地根据自身内部的状态改变对象的行为。
java.util.Iterator
javax.faces.lifecycle.LifeCycle#execute()
Strategy:
定义一组算法,并把其封装到一个对象中。然后在运行时,可以灵活的使用其中的一个算法。
java.util.Comparator#compare()
javax.servlet.http.HttpServlet
javax.servlet.Filter#doFilter()
Template method:
允许子类重载部分父类而不需要完全重写。
java.util.Collections#sort()
java.io.InputStream#skip()
java.io.InputStream#read()
java.util.AbstractList#indexOf()
Visitor:
作用于某个对象群中各个对象的操作. 它可以使你在不改变这些对象本身的情况下,定义作用于这些对象的新操作.
javax.lang.model.element.Element 和javax.lang.model.element.ElementVisitor
javax.lang.model.type.TypeMirror 和javax.lang.model.type.TypeVisitor
Adapter:
把一个接口或是类变成另外一种。
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()
Bridge:
把抽象和实现解藕,于是接口和实现可在完全独立开来。
AWT (提供了抽象层映射于实际的操作系统)
JDBC
Composite:
让使用者把单独的对象和组合对象混用。
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)
Decorator:
为一个对象动态的加上一系列的动作,而不需要因为这些动作的不同而产生大量的继承类。这个模式在JDK中几乎无处不在,所以,下面的列表只是一些典型的。
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]()
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
Creational(创建模式)
Abstract factory:
创建一组有关联的对象实例。这个模式在JDK中也是相当的常见,还有很多的framework例如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:
主要用来简化一个复杂的对象的创建。这个模式也可以用来实现一个 Fluent Interface。
java.lang.StringBuilder#append()
java.lang.StringBuffer#append()
java.sql.PreparedStatement
javax.swing.GroupLayout.Group#addComponent()
Factory:
简单来说,按照需求返回一个类型的实例。
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()
Prototype:
使用自己的实例创建另一个实例。有时候,创建一个实例然后再把已有实例的值拷贝过去,是一个很复杂的动作。所以,使用这个模式可以避免这样的复杂性。
java.lang.Object#clone()
java.lang.Cloneable
Singleton:
只允许一个实例。在 Effective Java中建议使用Emun.
java.lang.Runtime#getRuntime()
java.awt.Toolkit#getDefaultToolkit()
java.awt.GraphicsEnvironment#getLocalGraphicsEnvironment()
java.awt.Desktop#getDesktop()
Behavioral(行为模式)
Chain of responsibility:
把一个对象在一个链接传递直到被处理。在这个链上的所有的对象有相同的接口(抽象类)但却有不同的实现。
java.util.logging.Logger#log()
javax.servlet.Filter#doFilter()
Command:
把一个或一些命令封装到一个对象中。
java.lang.Runnable
javax.swing.Action
Interpreter:
一个语法解释器的模式。
java.util.Pattern
java.text.Normalizer
java.text.Format
Iterator:
提供一种一致的方法来顺序遍历一个容器中的所有元素。
java.util.Iterator
java.util.Enumeration
Mediator:
用来减少对象单的直接通讯的依赖关系。使用一个中间类来管理消息的方向。
java.util.Timer
java.util.concurrent.Executor#execute()
java.util.concurrent.ExecutorService#submit()
java.lang.reflect.Method#invoke()
Memento:
给一个对象的状态做一个快照。Date类在内部使用了一个long型来做这个快照。
java.util.Date
java.io.Serializable
Null Object:
这个模式用来解决如果一个Collection中没有元素的情况。
java.util.Collections#emptyList()
java.util.Collections#emptyMap()
java.util.Collections#emptySet()
Observer:
允许一个对象向所有的侦听的对象广播自己的消息或事件。
java.util.EventListener
javax.servlet.http.HttpSessionBindingListener
javax.servlet.http.HttpSessionAttributeListener
javax.faces.event.PhaseListener
State:
这个模式允许你可以在运行时很容易地根据自身内部的状态改变对象的行为。
java.util.Iterator
javax.faces.lifecycle.LifeCycle#execute()
Strategy:
定义一组算法,并把其封装到一个对象中。然后在运行时,可以灵活的使用其中的一个算法。
java.util.Comparator#compare()
javax.servlet.http.HttpServlet
javax.servlet.Filter#doFilter()
Template method:
允许子类重载部分父类而不需要完全重写。
java.util.Collections#sort()
java.io.InputStream#skip()
java.io.InputStream#read()
java.util.AbstractList#indexOf()
Visitor:
作用于某个对象群中各个对象的操作. 它可以使你在不改变这些对象本身的情况下,定义作用于这些对象的新操作.
javax.lang.model.element.Element 和javax.lang.model.element.ElementVisitor
javax.lang.model.type.TypeMirror 和javax.lang.model.type.TypeVisitor
发表评论
-
看大牛如何串口编程
2016-04-15 09:41 4151序言 说到开源 ... -
海量数据采集——645协议解析
2016-04-12 00:19 4842该通信规约适用于本地系统中多功能表的费率装置与手持单 ... -
海量数据采集——376.1协议解析
2016-04-06 10:16 23559Q / GDW 376.1—2009电力用户用电信息采集系 ... -
jeecg入门配置
2015-03-18 00:54 2363(1)下载: 首先从jeecg 社区下载jeecg最新安装 ... -
正确使用 hashCode 和 equals 方法
2013-10-11 18:21 2949hashCode()和equals()定义在Object类中 ... -
newInstance()方法和new关键字的区别
2013-04-22 16:47 4003* 它们的区别在于创建对象的方式不一样,前者是使用类 ... -
java反射
2013-04-21 20:03 1748Java反射是Java被视为 ... -
java泛型孔子问
2013-04-20 19:27 1131孔夫子问:“java泛型 ... -
System.out.println()的真正含义
2013-04-20 15:45 1619我们常常用System.out.println()方法来 ... -
java原生类型
2013-04-20 14:33 2050Java中,数据类型分为基本数据类型(或叫做原生类、内置类型 ... -
接口,工厂
2012-07-05 17:31 1180接口的作用 接口的作用简单一点就是:接口是用来标记类 ... -
JAVA中 @Override 的作用
2012-06-22 19:44 3009如果想重写父类的方法,比如toString()方法的话, ... -
Hibernate中VO与PO
2012-06-17 23:31 2444O/R Mapping -- Object Relationa ... -
JAVA的各种O
2012-06-17 23:17 1796PO(persistant object) 持久对 ... -
Java虚拟机类装载的原理及实现
2012-06-14 17:30 6389一、引言 Java虚 ... -
举例说明你什么时候会用抽象类,什么时候更愿意使用接口?
2012-06-13 10:04 39994接口和抽象类都按照“ ... -
private的访问权限
2012-05-17 03:00 1159非常基础的概念问题 第一:private, public, p ... -
java访问私有属性
2012-05-17 02:51 1200一直以来,Java初学者甚至有多年开发经验的人,都认为在该类的 ... -
Java中23种经典设计模式
2012-04-01 10:15 1578Java中23种设计模式 目录 1. 设计模式 3 1.1 创 ...
相关推荐
Java作为一门流行的编程语言,其标准库(JDK)中巧妙地融入了多种设计模式的应用。本文将详细介绍在JDK中体现的23种经典设计模式,并通过具体的代码示例进行说明。 #### 二、设计模式分类 设计模式可以大致分为三类...
通过阅读源码,我们可以学习到Java设计模式、类库实现以及API的内部工作机制。 在压缩包的文件名称列表中,我们看到了多个模块,例如"java.base"、"java.management"等,这些都是JDK11的核心模块。"java.base"是最...
本主题将深入探讨JDK中的重要工具、JVM(Java Virtual Machine)的垃圾回收机制以及23种经典的设计模式。 首先,JDK工具介绍: 1. `javac`:这是Java的编译器,用于将源代码编译成可执行的字节码。 2. `java`:这个...
3. **动态代理**:Java 1.6引入了更强大的动态代理机制,使得在运行时创建代理类成为可能,这对于实现AOP(面向切面编程)和其他设计模式非常有用。 4. **并发编程增强**:加入了`java.util.concurrent`包,提供了...
说出在标准JDK中使用的一些设计模式。** - **装饰器模式**:在Java I/O库中,如`BufferedReader`和`BufferedWriter`。 - **单例模式**:`java.util.Calendar`类中的实现。 - **工厂模式**:在`java.lang.Class`类...
深入研究JDK源代码,不仅可以帮助我们更好地理解和使用Java提供的各种API,还能让我们学习到优秀的编程实践和设计模式。比如,观察Collections类的静态工厂方法,可以学习如何编写高效且易于使用的工具类;研究...
在JDK 1.6中,org可能包含如Apache Commons、JUnit测试框架或其他标准库的源代码。对于开发者来说,这是一份宝贵的资源,可以帮助他们理解和使用这些库。 深入研究JDK 1.6源码包,不仅可以提升对Java平台的理解,还...
在Java开发环境中,JDK(Java Development Kit)不仅包含了运行Java程序所需的基础工具,还提供了一些示例程序,用于帮助开发者理解和学习Java的各种特性和功能。"JDK中的记事本demo源码"就是这样的一个例子,它展示...
8. **并行GC的改进**:在JDK8中,垃圾收集器进行了优化,例如G1(Garbage First)垃圾收集器成为服务器模式下的默认选择,提供了更好的性能和响应时间。 9. **新的JSR**:JDK8还包含了若干新的Java标准规范,如JSR ...
在JDK7中,虽然标准库中的com包并不突出,但有一些重要的组件,比如com.sun.*,其中包含了Sun Microsystems(现Oracle)提供的非公开API和实验性功能,虽然不建议直接使用,但在特定情况下可能需要。 【org】 org包...
2. **类型推断 for switch**:在`switch`语句中,可以使用`String`类型的变量,同时JDK 7支持泛型的类型推断,使代码更加灵活。 3. **钻石操作符** (`<>`):在创建泛型实例时,可以省略类型参数,编译器会根据上...
3. **学习设计模式**:JDK源代码中大量使用了各种设计模式,如工厂模式、单例模式等,是学习设计模式的好教材。 4. **性能优化**:通过源代码,可以了解到一些内部优化手段,比如集合类的扩容策略,有助于编写更高效...
- 通过查看源码,可以学习到如何在实际项目中应用设计模式,提高代码质量和可维护性。 - 对JVM的深入了解能帮助优化程序性能,解决运行时问题,如内存管理和线程调度。 总之,Java JDK 1.6.0源码是一个宝贵的教育...
4. **平台兼容性**:JDK 1.4.2_06是为32位Windows设计的,这意味着在64位操作系统上可能需要使用其他版本的JDK,或者使用兼容模式运行。现代操作系统可能不再支持非常老的JDK版本,因此寻找这些旧版本的资源变得困难...
这些源代码有助于开发者学习和掌握高级编程技巧和设计模式。 java 目录: 这是Java核心库的源代码,包括基础类库如集合框架、I/O流、多线程、网络编程等。通过对这些源代码的学习,开发者可以更好地理解和运用Java...
6. **设计模式与最佳实践**:分析源代码中的设计模式,学习Java社区的最佳编码实践。 7. **并发编程**:研究Fork/Join框架的实现,以及Concurrent包的改进,如Phaser和CountDownLatch。 8. **NIO.2**:了解新的...
在JavaBeans中,我们可以看到组件设计模式的实现,了解如何创建可重用的、基于组件的软件。JAXB则展示了如何将Java对象与XML数据绑定,而JAF则用于处理MIME类型的激活和数据处理。 接着,com目录是许多第三方库和...
在Java编程领域,动态代理是一种常见的设计模式,用于在运行时创建对象的代理,以便在调用实际目标方法之前或之后插入额外的行为。主要存在两种常见的动态代理技术:JDK动态代理和CGLIB(Code Generation Library)...
10. **新特性**:JDK17引入了一些新的特性和改进,例如Pattern Matching for instanceof(类型模式匹配)、Sealed Classes(密封类)以及Record Components(记录组件)等,这些都是为了提高代码的可读性和安全性。...
尽管这样做可以绕过安全检查,但不推荐这样做,因为它违反了Unsafe类设计中的单例原则,可能会导致在使用上出现不可预见的问题。 Unsafe类中的部分方法需要对JVM内部结构有深入的理解,例如获取和操作对象的字段...