JAVA --- 单例模式(8种)


什么是设计模式?

  1. 设计模式是程序员在面对同类软件工程设计问题所总结出来的有用的经验,模式不是代码,而是某类问题的通用解决方案,设计模式(Design pattern)代表了最佳的实践。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

  2. 设计模式的本质提高软件的维护性,通用性和扩展性,并降低软件的复杂度。

  3. 设计模式并不局限于某种语言,java,php,c++都有设计模式.

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

  1. 创建型模式:单例模式、抽象工厂模式、原型模式、建造者模式、工厂模式。

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

  3. 行为型模式:模版方法模式、命令模式、访问者模式、迭代器模式、观察者模式、中介者模式、备忘录模式、解释器模式(Interpreter模式)、状态模式、策略模式、职责链模式(责任链模式)

提示:以下是本篇文章正文内容,下面案例可供参考

一、单例模式

  1. 所谓类的单例设计模式,就是采取一定的方法保证在整个的软件系统中,对某个类只能存在一个对象实例,并且该类只提供一个取得其对象实例的方法(静态方法)。

  2. 单例模式有八种方式:

    1. 饿汉式 (静态常量)
    2. 饿汉式 (静态代码块)
    3. 懒汉式 (线程不安全)
    4. 懒汉式 (线程安全,同步方法)
    5. 懒汉式 (线程安全,同步代码块)
    6. 双重检查
    7. 静态内部类
    8. 枚举

1. 饿汉式(静态常量)

步骤如下:

  1. 构造器私有化 (防止 new )

  2. 在类的内部创建对象

  3. 向外提供一个静态的公共方法,getInstance()

    代码实现:

package exercise;

public class Singleton01 {
   

    // 私有化构造函数 使得不能再new出一个对象(因为单例模式只能存在一个对象实例)
    private Singleton01(){
   
    }

    // 先直接创建一个 Singleton01 实例
    private static Singleton01 instance = new Singleton01();

    // 向外面提供一个静态方法 getInstance() 用于返回实例
    public static Singleton01 getInstance(){
   
        return instance;
    }
}

优缺点说明:

  1. 优点:这种写法比较简单,就是在类装载的时候就完成实例化。避免了线程同步问题。
  2. 缺点: 在类装载的时候就完成实例化,没有达到Lazy Loading的效果。如果从始至终从未使用过这个实例,则会造成内存的浪费
  3. 这种方式基于classloder机制避免了多线程的同步问题,不过,instance在类装载时就实例化,在单例模式中大多数都是调用getInstance方法, 但是导致类装载的原因有很多种,因此不能确定有其他的方式(或者其他的静态方法)导致类装载,这时候初始化instance就没有达到lazy loading的效果
  4. 结论:这种单例模式可用,但是有可能造成内存浪费

2. 饿汉式(静态代码块)

步骤如下:

  1. 构造器私有化 (防止 new )

  2. 在类的内部创建对象

  3. 向外提供一个静态的公共方法,getInstance()

    代码实现:

package exercise;

public class Singleton01 {
   

    // 私有化构造函数 使得不能再new出一个对象(因为单例模式只能存在一个对象实例)
    private Singleton01(){
   
    }

    // 先直接创建一个 Singleton01 实例
    private static Singleton01 instance = new Singleton01();

    // 向外面提供一个静态方法 getInstance() 用于返回实例
    public static Singleton01 getInstance(){
   
        return instance;
    }
}

优缺点说明:

  1. 优点:这种写法比较简单,就是在类装载的时候就完成实例化。避免了线程同步问题。
  2. 缺点: 在类装载的时候就完成实例化,没有达到Lazy Loading的效果。如果从始至终从未使用过这个实例,则会造成内存的浪费
  3. 这种方式基于classloder机制避免了多线程的同步问题,不过,instance在类装载时就实例化,在单例模式中大多数都是调用getInstance方法, 但是导致类装载的原因有很多种,因此不能确定有其他的方式(或者其他的静态方法)导致类装载,这时候初始化instance就没有达到lazy loading的效果
  4. 结论:这种单例模式可用,但是有可能造成内存浪费

3. 懒汉式(线程不安全)

提供一个静态的公有方法,当使用到该方法时,才去创建 instance


代码实现:

package exercise;

public class Singleton03 {
   

    public static void main(String[] args) {
   
        System.out.println("懒汉式 1 , 线程不安全~")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值