Java设计模式之单例模式

1、单例设计模式

作用/价值:保证某类的对象只有一个

具体步骤:

步骤一:私有化本类所有的构造方法

步骤二:在本类中创建唯一对象

步骤三:提供外界获取唯一对象的方式(公共的、静态的)

2、两种方式

饿汉式:

弊端:在类加载的过程中就会创建唯一对象,对象创建时机较早,有浪费内存的情况存在;

优点:就算在多线程环境下,也一定可以保证对象是唯一的;

懒汉式:

优点:在需要唯一对象的时候才会去创建对象,对象出现的时机不早也不晚,不会有浪费内存的情况;

弊端:在多线程环境下,可能不能保证对象是唯一的(需要上锁去解决这个问题);

具体代码如下:

java 复制代码
/**
 * 单例设计模式之饿汉式
 * 弊端:在类加载的过程中就会创建唯一对象,对象创建时机较早,有浪费内存的情况存在
 * 优点:就算在多线程环境下,也一定可以保证对象是唯一的
 */
public class Sun {
    private Sun() {

    }

    //这里final修饰可以不用加
    private static final Sun s = new Sun();

    public static Sun getInstance() {
        return s;
    }

    public static void test() {
        System.out.println("单例模式之饿汉式");
    }
}
java 复制代码
/**
 * 单例设计模式之懒汉式
 * 优点:在需要唯一对象的时候才会去创建对象,对象出现的时机不早也不晚,不会有浪费内存的情况
 * 弊端:在多线程环境下,可能不能保证对象是唯一的(需要上锁去解决这个问题)
 */
public class Moon {
    private Moon() {

    }

    //这里可以不用赋值null,默认也会给null
    private static Moon m = null;

    public static Moon getInstance() {
        if (m == null) {
            m = new Moon();
        }
        return m;
    }

    public static void test() {
        System.out.println("单例模式之懒汉式");
    }
}
java 复制代码
public class Main {
    public static void main(String[] args) {
        Sun s1 = Sun.getInstance();
        Sun s2 = Sun.getInstance();
        Moon m1 = Moon.getInstance();
        Moon m2 = Moon.getInstance();
        System.out.println(s1 == s2);   //结果为true
        System.out.println(m1 == m2);   //结果为true
    }
}
相关推荐
小杨互联网29 分钟前
项目CyberScan Pro jar软件安全成分分析插件
java·jar·软件成分分析·jar安全分析
组合缺一42 分钟前
Java 版 Claude Code CLI 来了!(国产开源项目)Solon Code CLI 发布
java·ai·开源·llm·solon·cli·claudecode
javaIsGood_2 小时前
Java基础面试题
java·开发语言
indexsunny2 小时前
互联网大厂Java求职面试实战:基于电商场景的技术问答及解析
java·spring boot·redis·kafka·security·microservices·面试指导
Forget_85502 小时前
RHEL——LVS模式
java·开发语言·lvs
渣瓦攻城狮2 小时前
互联网大厂Java面试:从数据库连接池到分布式缓存及微服务
java·redis·spring cloud·微服务·hikaricp·数据库连接池·分布式缓存
罗超驿3 小时前
13.1 万字长文,深入解析--抽象类和接口
java·开发语言
A懿轩A3 小时前
【Java 基础编程】Java 面向对象进阶:static/final、抽象类、接口、单例模式
java·开发语言·单例模式
lifallen3 小时前
后缀数组 (Suffix Array)
java·数据结构·算法
逆境不可逃3 小时前
LeetCode 热题 100 之 76.最小覆盖子串
java·算法·leetcode·职场和发展·滑动窗口