设计模式总结

一、为什么用设计模式?

使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。

代理模式可以请求打印日志信息,工厂模式可以负责初始化一些,观察者模式可以对事件的监听,单例模式,一定会手写单例

策略设计模式

二、设计模式分类

设计模式总共23种,分为三类:

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

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

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

三、懒汉式和饿汉式

懒汉式:

package Singleton;
/*懒汉式单例模式
* */
class Single{
    private static Single single;
    public static Single getSingle(){

            if (single==null){
                synchronized (Single.class){
                single = new Single();
                }
            }
            return single ;


    }
    /*为什么在java中单例设计模式要私有化该类构造函数?
    因为只有构造函数私有化了,才不能用new方法来创建对象,new创建对象时创建的是构造函数,如果可以用new方法就可以创建多个实例了,就不是单例模式了
    * */
    private Single(){

    }
}
public class SingletonTest {
    public static void main(String[] args) {
      //  Single single = new Single();
        Single single1 = Single.getSingle();
        Single single2 = Single.getSingle();
     //   System.out.println(single==single1);
        System.out.println(single1==single2);

    }
}

饿汉式:

package Singleton;
/*饿汉试单例模式
* */
class Single2{
    private Single2(){

    }
    private static final Single2 single2=new Single2();

    public static Single2 getSingle(){
        return single2;
    }
}
public class SingleTest2 {
    public static void main(String[] args) {
        Single2 single1 = Single2.getSingle();
        Single2 single2 = Single2.getSingle();
        System.out.println(single1==single2);
    }
}

懒汉式和饿汉试比较有哪些优缺点:

懒汉式节约内存,但是线程不安全,需要使用synchornized,运行效率低。饿汉式天生线程安全,执行效率高。

四、简单工厂模式和工厂模式

代码参考:https://github.com/WangShuaiFa/paactise-SlimpleFactory

https://github.com/WangShuaiFa/practise-Factory 

五、代理模式

1.什么是代理模式?

设计模式就是控制一个对象的访问。像租房子的时候中介一样,签合同时只和中介打交道就可以了,根本没有见过房东。

2.设计模式的应用场景

1)安全代理,可屏蔽真实角色。

2)远程代理,调用框架RMI。延展如下:

spring aop优点:控制安全性,RMI框架调用(用的不多,只支持java,重点关注http和webservice)

3)延迟加载 ,先加载轻量级代理类,真正需要再加载真实。

3.代理模式的分类

静态代理和动态代理。二者的区别:

静态代理需要手动实现代理类

动态代理有:jdk自带动态代理、cglib、javaassist (字节码操作库);

注意:jdk自带动态代理使用JAVA的反射机制

jdk自带动态代理和cglib的区别?

1)jdk动态代理通过java反射机制来实现,而cglib底层实现通过asm实现的。

2)jdk动态代理执行效率低,cglib执行效率高(注:在jdk1.8之后jdk的效率高于cglib)

3)  jdk动态代理的应用前提,必须是目标类基于统一的接口。

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值