设计模式-创建者模式-单例模式(java版)

(有的事情需要提前说明一下,哥们英语不好,在自己学习过程中写的代码有的可能会以中文命名,介意者出门左拐,不介意的继续往下看)

定义:单例模式(Singleton Patern)是Java 中最简单的设计模式之一,此模式保证某个类在运行期间,只有一个实例对外提供服务,而这个类被称为单例类。

**单例模式要做的事情:**1、保证一个类只有一个实例;2、为该实例提供一个全局访问点。

单例模式-饿汉式:

java 复制代码
package org.example.test07.单例;

//在类加载期间初始化私有的静态实例,保证instance实例创建过程是线程安全的
//不支持延时加载,如果需要创建的对象较大且一直没有使用,就会造成内存的浪费

public class 饿汉式 {

//私有构造方法
    private 饿汉式() {

    }
//在本类中创建私有静态的全局对象
    private static 饿汉式 instance=new 饿汉式();

//提供一个全局的静态访问点,跟随类的加载而加载,供外部获取该单例对象
    public static 饿汉式 getInstance(){
        return instance;
    }

}

单例模式-懒汉式(线程不安全):

java 复制代码
package org.example.test07.单例;

public class 懒汉式_线程不安全 {
    private 懒汉式_线程不安全(){

    }

    private static 懒汉式_线程不安全 instance;

    public static 懒汉式_线程不安全 getInstance(){
        if (instance==null){
          instance=new 懒汉式_线程不安全();
        }
        return instance;
    }
}

单例模式-懒汉式(线程安全):

java 复制代码
package org.example.test07.单例;

//并发度很低
public class 懒汉式_线程安全 {
    private 懒汉式_线程安全(){

    }

    private static 懒汉式_线程安全 instance;

    public static synchronized 懒汉式_线程安全 getInstance(){
        if (instance==null){
          instance=new 懒汉式_线程安全();
        }
        return instance;
    }
}

单例模式-懒汉式(线程安全双重校验):

java 复制代码
package org.example.test07.单例;

//并发度很高
public class 懒汉式_线程安全_双重校验 {
    private 懒汉式_线程安全_双重校验(){

    }

    //添加volatile防止指令重排
    private static volatile 懒汉式_线程安全_双重校验 instance;

    public static synchronized 懒汉式_线程安全_双重校验 getInstance(){
        if (instance==null){
            synchronized (懒汉式_线程安全_双重校验.class){
                if (instance==null){
                    //1、分配内存空间
                    //2、初始化对象
                    //3、将instance指向分配好的内存空间
                    instance=new 懒汉式_线程安全_双重校验();
                }
            }
        }
        return instance;
    }
}

单例模式-饿汉式(静态内部类,防止反射破坏单例):

java 复制代码
package org.example.test07.单例;
//被static修饰的不会被gc回收
public class 静态内部类 {

    private 静态内部类() {
        //防止反射对单例的破坏
        if(单例Handler.instance!=null){
            throw new RuntimeException("不允许非法访问");
        }
    }


    private static class 单例Handler{
        private static 静态内部类 instance=new 静态内部类();
    }

    public static 静态内部类 getInstance(){
        return 单例Handler.instance;
    }

    //防止反序列化对单例的破坏
    //当对象流传输时会检测序列化类中是否包含此方法,在反序列化过程中,该方法会返回原始的单例实例,而不会创建新的实例。可以肯定的是,在这种情况下单例模式的确是可以生效的。
    private Object readResolve(){
        return 单例Handler.instance;
    }


}

单例模式-枚举:

java 复制代码
package org.example.test07.单例;

public enum 枚举方式 {


    INSTANCE;

    private Object data;

    public Object getData(){
        return data;
    }
   public void setData(Object data){
        this.data=data;
   }

    public static 枚举方式 getInstance(){
        return INSTANCE;
    }

}
相关推荐
凯尔萨厮1 分钟前
Springboot2.x+Thymeleaf项目创建
java
fish_xk13 分钟前
map和set
java·开发语言
李崧正28 分钟前
Java技术分享:Lambda表达式与函数式编程
java·开发语言·python
老了,不知天命30 分钟前
鳶尾花項目JAVA
java·开发语言·机器学习
二哈赛车手36 分钟前
新人笔记---实现简易版的rag的bm25检索(利用ES),以及RAG上传时的ES与向量数据库双写
java·数据库·笔记·spring·elasticsearch·ai
winner888139 分钟前
从零吃透C++命名空间、std、#include、string、vector
java·开发语言·c++
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题】【Java基础篇】第26题:Java的抽象类和接口有哪些区别
java·开发语言·面试
bzmK1DTbd1 小时前
SOLID原则在Java中的实践:单一职责与开闭原则
java·开发语言·开闭原则
winner88811 小时前
C++ 命名空间、虚函数、抽象类、protected 权限全套通俗易懂精讲(附与 Java 对比)
java·开发语言·c++
直奔標竿1 小时前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring