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中实现单例模式的一些常见方法。选择哪种方式取决于你的需求,包括是否需要延迟加载、线程安全以及可扩展性等。

相关文章
|
2月前
|
设计模式 缓存 安全
【设计模式】【创建型模式】单例模式(Singleton)
一、入门 什么是单例模式? 单例模式是一种设计模式,确保一个类只有一个实例,并提供一个全局访问点。它常用于需要全局唯一对象的场景,如配置管理、连接池等。 为什么要单例模式? 节省资源 场景:某些对象创
115 15
|
2月前
|
人工智能 安全 Java
Java并发包下Atomic相关类的使用
本文介绍了 `java.util.concurrent.atomic` 包下的各类原子类及其使用场景,包括基本类型原子类(如 `AtomicInteger`、`AtomicLong`)、数组类型原子类(如 `AtomicIntegerArray`)、引用类型原子类(如 `AtomicReference`)、对象属性修改原子类(如 `AtomicIntegerFieldUpdater`)以及原子操作增强类(如 `LongAdder` 和 `LongAccumulator`)。同时,详细对比了不同原子类在高并发场景下的性能表现,展示了 `LongAdder` 的高效性。
91 31
|
2月前
|
存储 安全 Java
【高薪程序员必看】万字长文拆解Java并发编程!(7):不可变类设计指南
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中Java不可变类设计指南,废话不多说让我们直接开始。
43 0
|
3月前
|
Java 数据安全/隐私保护
Java 类和对象
本文介绍了Java编程中类和对象的基础知识,作为面向对象编程(OOP)的核心概念。类是对象的蓝图,定义实体类型;对象是具体实例,包含状态和行为。通过示例展示了如何创建表示汽车的类及其实例,并说明了构造函数、字段和方法的作用。同时,文章还探讨了访问修饰符的使用,强调封装的重要性,如通过getter和setter控制字段访问。最后总结了类与对象的关系及其在Java中的应用,并建议进一步学习继承等概念。
|
3月前
|
Java
java中一个接口A,以及一个实现它的类B,一个A类型的引用对象作为一个方法的参数,这个参数的类型可以是B的类型吗?
本文探讨了面向对象编程中接口与实现类的关系,以及里氏替换原则(LSP)的应用。通过示例代码展示了如何利用多态性将实现类的对象传递给接口类型的参数,满足LSP的要求。LSP确保子类能无缝替换父类或接口,不改变程序行为。接口定义了行为规范,实现类遵循此规范,从而保证了多态性和代码的可维护性。总结来说,接口与实现类的关系天然符合LSP,体现了多态性的核心思想。
80 0
|
2月前
|
设计模式 Java 数据库连接
【设计模式】【创建型模式】工厂方法模式(Factory Methods)
一、入门 什么是工厂方法模式? 工厂方法模式(Factory Method Pattern)是一种创建型设计模式,它定义了一个用于创建对象的接口,但由子类决定实例化哪个类。工厂方法模式使类的实例化延迟
86 16
|
2月前
|
设计模式 负载均衡 监控
并发设计模式实战系列(2):领导者/追随者模式
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发设计模式实战系列,第二章领导者/追随者(Leader/Followers)模式,废话不多说直接开始~
63 0
|
2月前
|
设计模式 监控 Java
并发设计模式实战系列(1):半同步/半异步模式
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发设计模式实战系列,第一章半同步/半异步(Half-Sync/Half-Async)模式,废话不多说直接开始~
50 0
|
2月前
|
设计模式 安全 Java
并发设计模式实战系列(12):不变模式(Immutable Object)
🌟 大家好,我是摘星!🌟今天为大家带来的是并发设计模式实战系列,第十二章,废话不多说直接开始~
47 0
|
2月前
|
设计模式 算法 Java
设计模式觉醒系列(04)策略模式|简单工厂模式的升级版
本文介绍了简单工厂模式与策略模式的概念及其融合实践。简单工厂模式用于对象创建,通过隐藏实现细节简化代码;策略模式关注行为封装与切换,支持动态替换算法,增强灵活性。两者结合形成“策略工厂”,既简化对象创建又保持低耦合。文章通过支付案例演示了模式的应用,并强调实际开发中应根据需求选择合适的设计模式,避免生搬硬套。最后推荐了JVM调优、并发编程等技术专题,助力开发者提升技能。

热门文章

最新文章