Java中的单例模式是一种设计模式,它保证一个类只有一个实例,并提供一个全局访问点

简介: Java单例模式确保类仅有一个实例,并提供全局访问点。常见实现包括:- 饿汉式:静态初始化,线程安全。- 懒汉式:延迟初始化,需同步保证线程安全。- 双重检查锁定:优化懒汉式,减少同步开销。- 静态内部类:延迟加载,线程安全。- 枚举:简洁线程安全,不适用于复杂构造。- 容器实现:如Spring框架,用于依赖注入。选择依据需求,如延迟加载、线程安全和扩展性。

Java中的单例模式是一种设计模式,它保证一个类只有一个实例,并提供一个全局访问点。根据实现方式的不同,有多种不同的实现单例模式的方法。以下是几种常见的Java单例模式的实现方式:

饿汉式(Eager Initialization):
静态初始化时创建唯一实例。
线程安全,因为实例在类加载时就创建了。
public class Singleton {

private static final Singleton INSTANCE = new Singleton();

private Singleton() {

}

public static Singleton getInstance() {

    return INSTANCE;
}

}
懒汉式(Lazy Initialization):
当第一次被请求时才创建唯一实例。
由于线程不安全,可能会产生多个实例,需要添加同步代码块或锁来确保线程安全。
public class Singleton {

private volatile static Singleton instance;

private Singleton() {

}

public static synchronized Singleton getInstance() {

    if (instance == null) {

        instance = new Singleton();
    }
    return instance;
}

}
双重检查锁定(Double-Checked Locking):
基于懒汉式的改进版本,只有在第一次实例化时才进行同步,避免每次获取实例都进行同步操作。
自从JDK 1.5及更高版本支持volatile关键字后,这是一种推荐的实现方法。
public class Singleton {

private volatile static Singleton instance;

private Singleton() {

}

public static Singleton getInstance() {

    if (instance == null) {

        synchronized (Singleton.class) {

            if (instance == null) {

                instance = new Singleton();
            }
        }
    }
    return instance;
}

}
静态内部类(Static Nested Class):
利用静态内部类的特性,在外部类被加载时并不会立即初始化静态内部类,因此实现了延迟加载。
只有当第一次调用getInstance()方法时才会加载静态内部类并创建唯一的实例。
这种实现是线程安全的,而且没有性能开销。
public class Singleton {

private Singleton() {

}

private static class SingletonHolder {

    private static final Singleton INSTANCE = new Singleton();
}

public static Singleton getInstance() {

    return SingletonHolder.INSTANCE;
}

}
枚举(Enum):
使用枚举可以很容易地创建单例,且枚举默认是线程安全的。
枚举的方式简洁,但可能不适合一些需要控制构造过程或者与其他设计模式结合的情况。
public enum Singleton {

INSTANCE;

public void doSomething() {

    //...
}

}

// 获取单例实例
Singleton singleton = Singleton.INSTANCE;
singleton.doSomething();
容器实现(Container):
可以使用Spring框架或其他依赖注入框架提供的机制来创建和管理单例对象。
以上就是Java中实现单例模式的一些常见方法。选择哪种方式取决于你的需求,包括是否需要延迟加载、线程安全以及可扩展性等。

相关文章
|
4月前
|
设计模式 缓存 安全
【设计模式】【创建型模式】单例模式(Singleton)
一、入门 什么是单例模式? 单例模式是一种设计模式,确保一个类只有一个实例,并提供一个全局访问点。它常用于需要全局唯一对象的场景,如配置管理、连接池等。 为什么要单例模式? 节省资源 场景:某些对象创
150 15
|
4月前
|
设计模式 缓存 安全
【高薪程序员必看】万字长文拆解Java并发编程!(8):设计模式-享元模式设计指南
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中的经典对象复用设计模式-享元模式,废话不多说让我们直接开始。
95 0
|
2月前
|
安全 Java 测试技术
Java 大学期末实操项目在线图书管理系统开发实例及关键技术解析实操项目
本项目基于Spring Boot 3.0与Java 17,实现在线图书管理系统,涵盖CRUD操作、RESTful API、安全认证及单元测试,助力学生掌握现代Java开发核心技能。
98 1
|
3月前
|
人工智能 Java 开发者
【Java实例-简易计算机】使用Java实现简单的计算机案例
一个简单的Java案例——“简易计算器”,帮助编程新手快速上手。通过实现用户输入、基本逻辑运算和结果输出,学习者可以掌握变量声明、Scanner对象使用、控制流语句等关键知识点。文章分为设计思路、关键知识点、完整代码和测试运行四个部分。
122 9
【Java实例-简易计算机】使用Java实现简单的计算机案例
|
4月前
|
Java 测试技术 项目管理
【JavaEE】从 0 到 1 掌握 Maven 构建 Java 项目核心技巧 解锁 Java 项目高效管理实用实例
本文从Maven基础概念讲起,涵盖安装配置、核心概念(如POM与依赖管理)及优化技巧。结合Java Web项目实例,演示如何用Maven构建和管理项目,解决常见问题,助你高效掌握这一强大工具,提升Java开发与项目管理能力。适合初学者及进阶开发者学习。资源链接:[点此获取](https://pan.quark.cn/s/14fcf913bae6)。
146 6
|
3月前
|
Java 开发者
【Java实例-神秘年龄】用Java挑战你的直觉
我们一起走进这款款简单却充满趣味的Java小游戏——“神秘年龄”。这款游戏不仅适合编程初学者作为练习项目,也能为有一定基础的开发者提供一个轻松的编程小憩。
38 0
【Java实例-神秘年龄】用Java挑战你的直觉
|
3月前
|
Java 开发者
【Java实例-神秘硬币】用Java投掷你的幸运硬币,你是猜正还是反?
本文分享了一个简单有趣的编程案例——猜硬币正反面游戏。通过模拟抛硬币(0为正面,1为反面),用户输入猜测值,程序判断结果并输出。
101 0
【Java实例-神秘硬币】用Java投掷你的幸运硬币,你是猜正还是反?
|
3月前
|
存储 算法 Java
【Java实例-智慧牌局】Java实现赌桌上的21点
游戏规则:游戏开始时,玩家和庄家各获得两张牌,玩家可以看到自己手中的两张牌以及庄家的一张明牌。玩家需要根据手中的牌面总和,选择“要牌”(Hit)以获取更多牌,或“停牌”(Stand)停止要牌。如果玩家的牌面总和超过21点,即为爆牌,玩家立即输掉游戏。若玩家选择停牌,庄家则开始行动,其策略是当牌面总和小于17点时必须继续要牌。若庄家牌面总和超过21点,则庄家爆牌,玩家获胜。若双方均未爆牌,最终比较牌面总和,更接近21点的一方获胜;若牌面总和相同,则游戏以平局结束。
53 0
|
3月前
|
Java 开发者
【Java实例-英雄对战】Java战斗之旅,既分胜负也决生死
游戏规则:在“英雄对战”中,玩家和敌人轮流选择行动,目标是在对方生命值归零前将其击败。游戏开始时,玩家和敌人都有100生命值。每回合,玩家可以选择“攻击”,“追击”,“闪避反击”这三种行动之一。
44 0
|
3月前
|
Java
【Java实例-小兵拆炸弹】Java打造数学挑战-拆炸弹
今天,我将向大家分享一款用Java开发的控制台小案例——“小兵拆炸弹”。游戏规则:玩家需要在有限的尝试次数内解开一系列数学题,以成功拆解炸弹。游戏的目标是连续答对五道数学题,每道题都由系统随机生成。如果玩家在五次机会内成功解密,游戏胜利;否则,炸弹爆炸,游戏结束。
59 0