iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >浅析Java单例设计模式(自写demo)
  • 356
分享到

浅析Java单例设计模式(自写demo)

2024-04-02 19:04:59 356人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录单例模式特点单例模式优点实现方式饿汉式(线程安全)懒汉式单例模式特点 1、构造器私有 2、在一个Java应用程序中,可保证只有一个实例对象 3、只提供一个供外界调用的getIns

单例模式特点

1、构造器私有

2、在一个Java应用程序中,可保证只有一个实例对象

3、只提供一个供外界调用的getInstance()方法

单例模式优点

1、减少某些对象的频繁创建,降低系统开销和内存占用

2、外部调用不使用new关键字,降低系统内存的使用频率

3、对于特殊的类,在系统中只能存在一个实例,否则系统无法正常运行,比如Controller

实现方式

这里简单介绍两种实现方式

饿汉式(线程安全)



public class Singleton {
    //创建实例
    private static Singleton instance = new Singleton();
 
    //私有构造器
    private Singleton(){
    }
 
    //获取实例的静态方法
    public static Singleton getInstance(){
        return instance;
    }
 
}

实例对象在类被加载的时候就已经完成初始化,外界调用拿到的都是这个唯一的实例对象

懒汉式



public class Singleton {
    //声明一个变量
    private static Singleton instance;
 
    //私有构造器
    private Singleton(){
    }
 
    //获取实例的静态方法
    public static Singleton getInstance(){
        //如果是首次调用,实例对象还没有被创建,就需要创建,否则都是返回已经创建过的那个对象
        if (instance == null){
            instance = new Singleton();
        }
        return instance;
    }
 
}

对比饿汉式可见,实例对象在类被加载的时候并没有进行创建,在首次调用的时候才被创建,以后再被调用,返回的也是那个唯一的实例对象。

多线程情况下,这种写法存在线程安全问题,比如:线程A在执行完if判断条件后进入阻塞状态,此时并没有进行对象创建,此时线程B来了,在执行完if条件后直接进行对象创建,等线程A恢复运行状态后也会进行对象创建,这个时候就不符合单例模式了,即出现了线程不安全的问题。

解决方案:在获取实例的静态方法上加synchronized关键字,即加



public class Singleton {
    //声明一个变量
    private static Singleton instance;
 
    //私有构造器
    private Singleton(){
    }
 
    //获取实例的静态方法
    public static synchronized Singleton getInstance(){
        //如果是首次调用,实例对象还没有被创建,就需要创建,否则都是返回已经创建过的那个对象
        if (instance == null){
            instance = new Singleton();
        }
        return instance;
    }
 
}

简单粗暴,可达到我们的目的,但是每次获取实例对象都要有加锁操作,影响系统性能。

改进后的方案:双重检查



public class Singleton {
    //声明一个变量
    private static Singleton instance;
 
    //私有构造器
    private Singleton(){
    }
 
    //获取实例的静态方法
    public static synchronized Singleton getInstance(){
        //第一次检查
        if (instance == null){
            //获取锁
            synchronized (Singleton.class){
                //第二次检查
                if (instance==null){
                    //两次检查都确定没有已存在的实例对象,这才进行对象的创建操作
                    instance = new Singleton();
                }
            }
            
        }
        return instance;
    }
 
}

这样不必每次获取实例对象的时候都进行加锁操作,只有在第一次创建对象的时候才进行加锁操作,提高了系统性能。

但是,即使这样有可能会出现。因为 instance = new Singleton()这行代码在JVM中是两个操作,赋值和初始化实例,但JVM并不保证这两个操作的顺序,有可能JVM给新对象分配了空间,直接赋值给instance变量,然后才去做初始化实例操作。比如下面这种情况

1,A,B两个线程都进入第一个if条件

2,A线程先抢到锁进入到synchronized代码块,执行了instance = new Singleton()这行代码,然后释放锁,此时有可能JVM只给实例对象分配了空白的内存空间,并没有执行初始化操作

3,B线程抢到锁,进入到synchronized代码块,第二次判断的时候发现instance不是null,直接返回使用却发现得到的对象还没有被初始化,于是出现了问题。

再次改进:使用volatile关键字修饰声明的成员变量instance



public class Singleton {
    //声明变量,被volatile修饰
    private volatile static Singleton instance;
 
    //私有构造器
    private Singleton(){
    }
 
    //获取实例的静态方法
    public static synchronized Singleton getInstance(){
        //第一次检查
        if (instance == null){
            //获取锁
            synchronized (Singleton.class){
                //第二次检查
                if (instance==null){
                    //两次检查都确定没有已存在的实例对象,这才进行对象的创建操作
                    instance = new Singleton();
                }
            }
 
        }
        return instance;
    }
 
}

volatile关键字作用:通过volatile修饰的变量,不会被线程本地缓存,所有线程对该对象的读写都会第一时间同步到主内存,从而保证多个线程间该对象的准确性。

这个写法已经比较完美了,既能保证安全的创建出唯一实例,又不会对系统性能有太大影响。

不过,还有更优的写法:静态内部类实现


​

public class Singleton {
 
    //私有构造器
    private Singleton() {
    }
 
    //静态内部类声明实例
    private static class SingletonFactory{
        private static Singleton instance = new Singleton();
    }
 
    //获取实例的静态方法
    public static Singleton getInstance(){
        return SingletonFactory.instance;
    }
    
}
 
​

使用内部类来维护单例的实现,JVM内部的机制能够保证当一个类被加载的时候,这个类的加载过程是线程互斥的。这样当我们第一次调用getInstance()方法的时候,JVM能够保证创建出唯一的实例对象,并且这个实例对象是已经被初始化完成的,就解决了上面的线程安全问题

最后一种实现单例的写法也很完美,代码最简洁

通过枚举



public enum Singleton {
 
    //代表一个Singleton实例
    INSTANCE;
}

通过枚举来实现单实例代码更加简洁,而且JVM从根本上保证实例对象的唯一性,是更简洁、高效、安全的实现单例的方式 

以上就是浅析Java单例设计模式(自写demo)的详细内容,更多关于Java单例模式的资料请关注编程网其它相关文章!

--结束END--

本文标题: 浅析Java单例设计模式(自写demo)

本文链接: https://www.lsjlt.com/news/159897.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 浅析Java单例设计模式(自写demo)
    目录单例模式特点单例模式优点实现方式饿汉式(线程安全)懒汉式单例模式特点 1、构造器私有 2、在一个Java应用程序中,可保证只有一个实例对象 3、只提供一个供外界调用的getIns...
    99+
    2024-04-02
  • 怎样浅析Java单例设计模式
    本篇文章给大家分享的是有关怎样浅析Java单例设计模式,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。单例模式特点构造器私有在一个Java应用程序中,可保证只有一个实例对象只提供...
    99+
    2023-06-22
  • java设计模式之单例模式解析
    单例模式是最简单但同时也是很重要的一种设计模式,优点有以下几个方面:当内存占用特别大的类需要频繁地创建销毁时,单例模式可以节省内存和提高性能,例如myBatis里面的sessionFactory当需要对文件做单一读写时,例如同一时间只能同时...
    99+
    2023-05-31
    java 设计模式 单例模式
  • Java设计模式的单例模式实例分析
    本文小编为大家详细介绍“Java设计模式的单例模式实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java设计模式的单例模式实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。什么是单例模式单例模式(S...
    99+
    2023-06-29
  • Java设计模式-单例模式
    单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建。这个类提供...
    99+
    2023-06-05
  • Java设计模式系列之深入浅出单例模式
    目录前言饿汉式懒汉式线程安全问题volatile的作用总结前言 我不知道大家工作或者面试时候遇到过单例模式没,面试的话我记得我当时在17年第一次实习的时候,就遇到了单例模式,面试官是...
    99+
    2024-04-02
  • Java设计模式之单例模式
    目录什么是设计模式?单例模式是什么?单例模式设计的原则是什么?Java实现单例模式的5种方式?懒汉饿汉静态内部类双重校验锁DCL(Double Check Lock)枚举(num)总...
    99+
    2024-04-02
  • Android设计模式之单例模式解析
    在日常开发过程中时常需要用到设计模式,但是设计模式有23种,如何将这些设计模式了然于胸并且能在实际开发过程中应用得得心应手呢?和我一起跟着《Android源码设计模式解析与实战》一书边学边应用吧!今天我们要讲的是单例模式定义确保某一个类只有...
    99+
    2023-05-30
    android 单例模式 之单
  • Java中的四种单例模式浅析
    前言近期在做支付,一开始图省事,也是为了调试方便,支付的alipayClient和tradeService都是使用的时候去拿,这样就会导致创建多次。为了节省资源,统一配置成单例模式。什么是单例Singleton(单例)是设计模式的一种,为了...
    99+
    2023-05-31
    java 单例模式 ava
  • Java设计模式之单例模式简介
    目录一、饿汉式(静态常量)二、饿汉式(静态代码块)三、懒汉式(线程不安全)四、懒汉式(线程安全,同步方法)五、懒汉式(线程不安全,同步代码块)六、双重检查( DCL )七、静态内部类...
    99+
    2024-04-02
  • JAVA设计模式之单例模式详解
    目录前言一、单例模式是什么?二、懒汉式单例三、饿汉式单例四、双重校验锁总结前言 在之前的文章里已经介绍了设计模式以及设计原则的概念,接下来我们从单例模式入手深入学习几种常用的JAVA...
    99+
    2024-04-02
  • Java设计模式之单例模式示例详解
    目录0.概述1.饿汉式1.1 饿汉式单例实现1.2 破坏单例的几种情况1.3 预防单例的破坏2.枚举饿汉式2.1 枚举单例实现2.2 破坏单例3.懒汉式4.双检锁懒汉式5.内部类懒汉...
    99+
    2024-04-02
  • Java设计者模式简单工厂模式的示例分析
    这篇文章主要介绍Java设计者模式简单工厂模式的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!简介简单工厂模式 (Simple Factory) 又叫静态工厂方法(Static Factory Method)...
    99+
    2023-05-30
    java
  • java设计模式中的单例模式简单介绍
    这篇文章主要介绍“java设计模式中的单例模式简单介绍”,在日常操作中,相信很多人在java设计模式中的单例模式简单介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java设计模式中的单例模式简单介绍”的疑...
    99+
    2023-06-02
  • 【python 设计模式】单例模式
    单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在。当你希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场。 比如,某个服务器程序的配置信息存放在一个文件中...
    99+
    2023-01-31
    模式 python
  • JAVA设计模式---单例模式你知道吗
    目录单例模式的介绍单例模式实现的八种方式饿汉式静态常量静态代码块懒汉式线程不安全的写法线程安全,同步锁—效率低,不推荐线程安全,同步代码块—无法解决线程安全问题,不推荐双重检查—解决...
    99+
    2024-04-02
  • 【Java】设计模式之单例模式与工厂模式
    ✅作者简介:热爱后端语言的大学生,CSDN内容合伙人 ✨精品专栏:C++面向对象 🔥系列专栏:JavaSE精品总结 文章目录   前言1、设计模式概念及分类2、单例模式2...
    99+
    2023-10-04
    java 单例模式 设计模式
  • Java创建型设计模式之单例模式
    目录介绍优点实现饿汉式懒汉式静态内部类枚举介绍 单例模式是一种创建型设计模式,其主要特点包括: 只有一个实例:单例模式确保系统中只有一个实例对象存在,所有对该对象的访问都是对同一个对...
    99+
    2023-05-18
    Java单例模式 Java创建型设计模式
  • Python设计模式——单例模式
    一、单例模式理论单例模式:    保证某一个类只有一个实例,而且在全局只有一个访问点优点:    1、由于单例模式要求在全局内只有一个实例,因而可以节省比较多的内存空间    2、全局只有一个接入点,可以更好地进行数据同步控制,避免多重占用...
    99+
    2023-01-31
    模式 Python
  • 深入浅析java设计模式中的代理模式
    这期内容当中小编将会给大家带来有关深入浅析java设计模式中的代理模式,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、什么是代理模式(Porxy)  概念:代理模式就是为其他对象提供一种代理以控制对这个...
    99+
    2023-05-31
    java ava 代理模式
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作