设计模式

单例模式

单例模式:
    类自己负责创建自己的对象
    同时确保只有单个对象被创建
    提供了一种访问其唯一的对象的方式,可以直接访问,不需要实例化该类的对象
单例模式简单实现:
    私有的构造函数
    类持有自己的对象作为属性
    对外提供唯一的public方法返回这个类本身
饿汉式和懒汉式:
    针对何时初始化自己的对象分饿汉式和懒汉式
    它俩线程安全只是针对不同线程取到的是同一个实例化对象,单例里其他的方法修改单例属性的就要另说
饿汉式(项目加载就存在)
    线程安全
    优点:没有加锁,执行效率会提高。
    缺点:类加载时就初始化,浪费内存。
懒汉式(调用方法才存在)
    线程安全
    优点:第一次调用才初始化,避免内存浪费。
    缺点:不同的线程可能会同时实例化这个对象,必须加锁 synchronized 才能保证单例,但加锁会影响效率。   
双检锁/双重校验锁(DCL,即 double-checked locking)
登记式/静态内部类
    使用内部类控制对象自己创建
    线程安全
    节省资源

单例模式可以通过反射机制来创建另一个实例
而Enum是java1.5新增的防止反射破坏的单例,推荐使用
demo:G:\project\demo\DesignPatterns\Singleton

ps: 多例:和上面唯一的不同时有多个对象被创建 :如连接池

工厂模式

工厂模式就是将new一个产品对象的方法交给一个对应的factory去实例化
我们想要实例化这个对象只要new一个工厂并调用它对外提供的接口就行
这样我们就可以控制生产产品的过程

针对于工厂类生产一种 or 多种产品(父类) 分 简单工厂 和 抽象工厂
简单工厂模式:
    简单工厂接口有个参数,根据参数new这个产品不同的实现对象
    针对一种产品的工厂
    如果产品多了就会导致工厂类泛滥
抽象工厂模式:
    一个工厂负责产生一系列的产品
    产品过多不会导致工厂类泛滥,如果这个系列数值很大的话
    缺点:如果要扩展产品品种,就要改动每个工厂的代码去增加生产这个新系列的方法,很麻烦
demo:
G:\project\demo\DesignPatterns\Factory

代理模式

代理模式

2个类:被代理类(业务类)和代理类 同时继承一个父类,有相同的方法
我们需要在业务类里加入日志,但是不改变业务类代码。
只需要new一个代理类,代理类里有一个被代理类对象,在调用代理类的方法时,加入日志,然后调用被代理类的方法即可

代理模式分 静态代理(扩展差,代理类泛滥) 和 动态代理
动态代理:
不需要为每个子类去写代理类,只需要一个动态代理了就行,扩展性好
底层实现为jdk动态代理,有点复杂,没研究
现在也能通过注解去写,更简单

demo:G:\project\demo\DesignPatterns\proxy

策略模式

策略模式

说白了就是将针对某一对象类型的复杂算法定义成策略接口
通过子类实现这种算法
以后需要对该对象进行这种算法时,直接将该对象传给策略接口实现类来实现算法
可以组合

demo G:\project\demo\DesignPatterns\Strategy

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值