注:个人笔记

一、设计模式分三大类:

创建型模式,共五种:工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式。

结构型模式,共七种:适配器模式、装饰器模式、代理模式、外观模式、桥接模式、组合模式、享元模式。

行为型模式,共十一种:策略模式、模板方法模式、观察者模式、迭代子模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式、中介者模式、解释器模式。

另外两种:并发型模式和线程池模式

二、六大原则

1、开闭原则(Open Close Principle)

开闭原则就是说对扩展开放,对修改关闭。在程序需要进行拓展的时候,不能去修改原有的代码,实现一个热插拔的效果。通俗一点就是:为了使程序的扩展性好,易于维护和升级。想要达到这样的效果,我们必须使用接口和抽象类。

2、里氏代换原则(Liskov Substitution Principle)

里氏代换原则(Liskov Substitution Principle LSP)面向对象设计的基本原则之一。 里氏代换原则中说,任何基类可以出现的地方,子类一定可以出现。 LSP是继承复用的基石,只有当衍生类可以替换掉基类,软件单位的功能不受到影响时,基类才能真正被复用,而衍生类也能够在基类的基础上增加新的行为。里氏代换原则是对“开-闭”原则的补充。实现“开-闭”原则的关键步骤就是抽象化。而基类与子类的继承关系就是抽象化的具体实现,所以里氏代换原则是对实现抽象化的具体步骤的规范。

3、依赖倒转原则(Dependence Inversion Principle)

就是面向接口编程,依赖于抽象而不依赖于具体。

4、接口隔离原则(Interface Segregation Principle)

使用多个隔离的接口,比使用单个接口要好,就是降低类之间的耦合度。

设计模式就是一个软件的设计思想,从大型软件架构出发,为了升级和维护方便,即:降低依赖,降低耦合。

5、迪米特法则(最少知道原则)(Demeter Principle)

一个实体应当尽量少的与其他实体之间发生相互作用,使得系统功能模块相对独立。

实际上还是面向接口或抽象类编程思想,就是不需要知道实体的真正实现是怎么样的,只要知道这个接口能够实现这个功能就行了。

6、合成复用原则(Composite Reuse Principle)

尽量使用合成/聚合的方式,而不是使用继承。因为java不支持多继承,而且继承也会出现父-子类之间的紧耦合关系,所以最好是使用多个接口或者抽象类进行实现,而且还可以方便多个功能复用。

拿jdk举个例,比如:ArrayList类实现了Serializable, Cloneable, Iterable, Collection, List, RandomAccess几个接口,每个接口都实现了一些独有的功能,把它们合成在一起实现就是一个ArrayList类,就实现了序列化、克隆,迭代,排序等等功能,而变换这些接口的组合就可以实现很多比如ArrayDeque,LinkedList等等功能不同的实现类。

三、23+2种设计模式

1、工厂方法模式

工厂方法模式分三种:(1)普通工厂方法模式(2)多个工厂方法模式(3)静态工厂方法模式

(1)普通工厂方法模式

描述:建立一个工厂类,对实现同一个接口的类进行实例的创建

实现1:GamePlayer --->实现play()方法

接口:Player--->play() 方法   {

实现2:BallPlayer --->实现play()方法

工厂类:PlayerFactory----> product()方法(用于生成player接口的两个实现类)

代码实现:

public class PlayerFactory{

public  Player product(String type){

//根据type参数判断是哪一个实现类并返回创建的实例,哪个都不是就返回null

return "gamePlayer".equals(type)?new BallPlayerImpl ():("ballPlayer".equals(type)?new GamePlayerImpl():null);

}

}

(2)多个工厂方法模式

描述:多个工厂模式就是在工厂模式的基础上去除了字符串判断,给每个实现类都创建一个方法
工厂类:
PlayerFactory--->productGame()方法(用于生成GamePlayer实现类);productBall()方法(用于生成BallGamer实现类)
代码实现:
public class PlayerFactory{
//生成GamePlayer实例
public Player productGame(){
return new GamePlayer();
}
//生成BallPlayer实例
public Player productBall(){
return new BallPlayer();
}
}

(3)静态工厂方法模式

描述:就是将工厂类里面的方法全部置为静态static方法,这样就不需要创建工厂类实例了,可以直接通过类名调用静态方法

代码实现:
public class PlayerFactory{
//生成GamePlayer实例
public static Player productGame(){
return new GamePlayer();
}
//生成BallPlayer实例
public static Player productBall(){
return new BallPlayer();
}
}

工厂方法模式总结:出现大量的实例需要被创建就可以使用工厂方法,比起前两种,静态工厂方法最为常用。

2、抽象工厂模式

描述:工厂方法模式有一个问题就是,类的创建依赖工厂类,也就是说,如果想要拓展程序,就必须对工厂类进行修改,这违背了闭包原则;所以,从设计角度考虑,有一定的问题,如何解决?就用到抽象工厂模式,创建多个工厂类,这样一旦需要增加新的功能,直接增加新的工厂类就可以了,不需要修改之前的代码。
通俗一点就是现在有个GamePlayerProduct工厂类,但是这个类中的product()方法只能创建GamePlayer类,要对工厂方法进行修改是违反闭包原则的(关于闭包,一般软件交付使用后是不允许修改的,只能在代码基础上增加),怎么办?在架构设计时就把这个问题考虑进去,使用工厂接口,有了这个接口,我们让GamePlayerProduct实现这个接口,以后如果有其它的类要创建工厂类也实现这个接口就解决了拓展性的问题。

代码实现:
工厂接口:
public interface  PlayerFactory{
public  Player product();
}
工厂类1:
public class GamePlayerFactory
implements PlayerFactory{
@Override
public Player product(){
return new GamePlayer();
}
}
工厂类2:
public class BallPlayerFactory implementsPlayerFactory{
@Override
public Player product(){
return new BallPlayer();
}
}

总结:抽象工厂方法只有一个好处:提高程序的拓展性

3、单例模式

描述:什么事单例模式,单例模式就是该对象在一个jvm虚拟机中只存在一个实例。
在实际的应用中,频繁的创建对象和GC操作都是比较耗费系统资源的,所以使用单例能够提高应用的整体性能。
在有些应用中,必须使用单例才能够保证系统的正确运行。
单例其实就是私有化构造方法,然后通过静态方法对外提供创建好的实例

(1)、最简单的单例实例(最常用)

public class Singleton {
//静态对象
private static Singelton  instance=new Singleton();
//私有化构造器,防止通过new创建实例(注:只能防止new创建,通过类反射可以调用私有构造器)
private Singleton(){}
//对外提供静态方法用于调用实例
public static Singleton getSingleton()
{
return instance;
}
}
或者通过静态块创建单例,效果跟上面一样
public class Singleton {
//静态对象
private static Singelton  instance=null;
//静态块,只在类第一次被调用时才会加载静态块
static{
instance=new Singleton();
}
//私有化构造器,防止通过new创建实例(注:只能防止new创建,通过类反射可以调用私有构造器)
private Singleton(){}
//对外提供静态方法用于调用实例
public static Singleton getSingleton()
{
return instance;
}
}

(2)、为了提高运行效率,可以延迟创建对象

public class Singleton {
//静态对象
private static Singelton  instance=null;
//私有化构造器,防止通过new创建实例(注:只能防止new创建,通过类反射可以调用私有构造器)
private Singleton(){}
//对外提供静态方法用于调用实例
public static Singleton getSingleton()
{
if(instance==null)
{
instance =new Singelton();
}
return instance;
}
}

这种方法只适合没有多线程的情况下,那么遇到多线程调用就需要加锁

public class Singleton {
//静态对象
private static Singelton  instance=null;
//私有化构造器,防止通过new创建实例(注:只能防止new创建,通过类反射可以调用私有构造器)
private Singleton(){}
//对外提供静态方法用于调用实例
public static Singleton getSingleton()
{
//加个锁块即可,为什么不在方法上加synchronized,因为这个方法本身是没有多线程问题的,线程问题出在:判断是否为空和创建实例的时候,这时候如果不加锁,多个线程就会发生多次创建实例的问题。
synchronized (instance) {  
if(instance==null)
{
instance =new Singelton();
}
}
return instance;
}
}

(3)、创建实例和获取实例分离设计

之所以会出现线程问题,就在于我们每次获取实例都要判断实例是否已经创建好,如果没有创建,就在该方法中创建一个实例,那么我们把创建实例这一步单独拿出来对外提供方法即可。这样就把线程问题解决了,但是复杂了外部调用方式,外部在调用的实例的时候就需要先调用getSingleton()判断取到实例是否为空,如果为空则再调用initSingleton()方法创建一个实例,然后再次getSingleton()获取实例。
public class Singleton {
//静态对象
private static Singelton  instance=null;
//私有化构造器,防止通过new创建实例(注:只能防止new创建,通过类反射可以调用私有构造器)
private Singleton(){}
//初始化实例
public static synchronized void initSingleton()
{
if(instance==null)
{
instance =new Singelton();
}
}
//调用实例
public static Singleton getSingleton()
{
return instance;
}
}

4、建造者模式

工厂模式是创建单个类的模式,建造者模式就是把各个类整合起来创建复合对象。

(1)单个类的多个实例

public class Examples{
private List<Example>  exampleList=new ArrayList<Example>();
//创建多个实例
public void productExamples(int num)
{
for(;num>0;num--)
{
exampleList.add(new Example());
}
}
public  List<Example> getExamples()
{
return exampleList;
}
}

(2)多个类多实例

public class Examples{
private Map<String,Object> map=new HashMap<String,Object>(10);
//创建多个类实例
public void
productExamples()
{
map.put("example1",new Example1());
map.put("example2",new Example2());
map.put("example3",new Example3());
map.put("example4",new Example4());
}
public Map<String,Object> getExamples()
{
return map;
}
}

5、原型模式

未完待续。。。

Java开发中的23+2种设计模式学习个人笔记(未完待续)的更多相关文章

  1. [ 转载 ] Java开发中的23种设计模式详解(转)

    Java开发中的23种设计模式详解(转)   设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类 ...

  2. java泛型基础、子类泛型不能转换成父类泛型--未完待续

    参考http://how2j.cn/k/generic/generic-generic/373.html 1.使用泛型的好处:泛型的用法是在容器后面添加<Type>Type可以是类,抽象类 ...

  3. Java开发中的23种设计模式详解

    [放弃了原文访问者模式的Demo,自己写了一个新使用场景的Demo,加上了自己的理解] [源码地址:https://github.com/leon66666/DesignPattern] 一.设计模式 ...

  4. Java开发中的23种设计模式详解(转)

    设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...

  5. Java开发中的23种设计模式(转)

    设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...

  6. Java开发中的23种设计模式具体解释

    public static void main(String[] args) { SendFactory factory = new SendFactory(); Sender sender = fa ...

  7. 0. Java开发中的23种设计模式详解(转)

    设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...

  8. (转)Java开发中的23种设计模式详解

    原文出自:http://blog.csdn.net/zhangerqing 一.设计模式的分类 总体来说设计模式分为三大类: 创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型 ...

  9. Java开发中的23种设计模式(转)

    设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...

随机推荐

  1. Extjs6(二)——用extjs6.0写一个系统登录及注销

    本文基于ext-6.0.0 一.写login页 1.在view文件夹中创建login文件夹,在login中创建文件login.js和loginController.js(login.js放在class ...

  2. XtraBackup 原理与安装

    简介 XtraBackup(PXB) 工具是 Percona 公司用 perl 语言开发的一个用于 MySQL 数据库物理热备的备份工具,支持 MySQl(Oracle).Percona Server ...

  3. 在同一个系统上装两个不同版本的jdk,配置环境变量不起作用,jdk版本的切换问题

    本人这台笔记本前面装了jdk8,现在准备用jdk7,我安装好了jdk7:把系统变量中的JAVA_HOME 改为 D:\java\jdk\jdk7\jdk1.7.0_67,Path 下添加如下变量,记得 ...

  4. java:Comparator比较器

    /*Comparator是java.util包里的一个接口,使用时应该实现导入相应的包, *再写一个实现了Comparator接口的类,并复写int compare(Object o)方法, *写出你 ...

  5. UML总结(对九种图的认识和如何使用Rational Rose 画图)

    UML是一种建模语言,是系统建模的标准.我们之所以建模是因为大规模的系统设计时相当复杂的,当系统比较复杂时就会涉及到以下这几个问题: 开发人员如何与用户进行沟通来了解系统的需求? 开发人员之间如何沟通 ...

  6. 新年伊始,.net菜鸟入院的第一篇随笔

    学习.net有半年了,大二一年都是微软校园的负责人,但是因为根本没有系统的学习过编程的知识,所以一直都是活动负责人的身份,忙忙碌碌也没有什么收获,大三一狠心就退了,想能够踏踏实实的敲敲代码,手上的学习 ...

  7. ASP.NET MVC, Url长度过长问题解决,404.15问题

    最近在处理一个问题的时候,发现他们存在一个大量数据放在URL中传递的过程,当数据达到一定数量的时候就会报出404.15问题. 运行环境是在IIS8,经过查询之后发现,URL此时最大长度为2048,肯定 ...

  8. 开源框架是如何通过JMX来做监控的(一) - JMX简介和Standard MBean

    相关文章目录: 开源框架是如何通过JMX来做监控的(一) - JMX简介和Standard MBean 开源框架是如何通过JMX来做监控的(二) - Druid连接池的监控 相信很多做Java开发的同 ...

  9. NodeJS安装第一个工程

    一.刚接触Node.js,下载好安装包后,一路Next,安装好后,结构目录如下 在命令行窗口输入node -v 和npm -v 二.建立一个Node.js工程 1.(控制台窗口)全局安装了expres ...

  10. 从.Net版本演变看String和StringBuild性能之争

    在C#中string关键字的映射实际上指向.NET基类System.String.System.String是一个功能非常强大且用途非常广泛的基类,所以我们在用C#string的时候实际就是在用.NE ...