创建型模式-单例模式

本文详细介绍了Java中的单例模式实现方式,包括懒汉式(线程不安全与线程安全)和饿汉式。懒汉式在多线程环境下可能造成实例化多次的问题,而线程安全的懒汉式通过同步锁解决了这一问题,但会带来性能损耗。饿汉式则在类加载时就完成了实例化,保证线程安全但失去了延迟初始化的优点。此外,还提到了静态内部类和枚举实现单例模式,这两种方式既保证了线程安全,又实现了延迟初始化,是较好的实践方案。

单例模式要点:

使用一个私有构造函数、一个私有静态变量以及一个公有静态函数来实现。私有构造函数保证了不能通过构造函数来创建对象实例,只能通过公有静态函数返回唯一的私有静态变量。

1.懒汉式

线程不安全实现
私有静态变量 uniqueInstance 被延迟实例化,这样做的好处是,如果没有用到该类,那么就不会实例化 uniqueInstance,从而节约资源。 这个实现在多线程环境下是不安全的,如果多个线程能够同时进入 if (uniqueInstance == null) ,并且此时 uniqueInstance 为 null,那么会有多个线程执行 uniqueInstance = new Singleton(); 语句,这将导致多次实例化 uniqueInstance

public class Singleton {
    private Singleton() {
    }

    private static Singleton uniqueInstance ;

    public static Singleton getUniqueInstance (){
        if (uniqueInstance  == null) {
            //线程不安全
            uniqueInstance = new Singleton();
        }
        return uniqueInstance;
    }

}

懒汉式,线程安全实现

public class Singleton {
    private Singleton() {
    }

    private volatile static Singleton uniqueInstance ;
    //有性能损耗,每次都得获取锁,才能获取实例
    public static synchronized Singleton getUniqueInstance (){
        if (uniqueInstance  == null) {
            uniqueInstance = new Singleton();
        }
        return uniqueInstance;
    }

}
public class Singleton {
    private Singleton() {
    }

    private volatile static Singleton uniqueInstance ;

    public static  Singleton getUniqueInstance (){
        if (uniqueInstance  == null) {
            synchronized(Singleton.class){
                if (uniqueInstance == null) { //双重检查
                    uniqueInstance = new Singleton();
                }
            }
        }
        return uniqueInstance;
    }

}

uniqueInstance 采用 volatile 关键字修饰也是很有必要的。uniqueInstance = new Singleton(); 这段代码其实是分为三步执行。 1分配内存空间 2初始化对象 3将 uniqueInstance 指向分配的内存地址, 但是由于 JVM 具有指令重排的特性,有可能执行顺序变为了 1>3>2,这在单线程情况下自然是没有问题。但如果是多线程下,有可能获得是一个还没有被初始化的实例,以致于程序出错。 使用 volatile 可以禁止 JVM 的指令重排,保证在多线程环境下也能正常运行

2.饿汉式

线程不安全问题主要是由于 uniqueInstance 被多次实例化,采取直接实例化 uniqueInstance 的方式就不会产生线程不安全问题。 但是直接实例化的方式也丢失了延迟实例化带来的节约资源的好处

public class Singleton {
    private Singleton() {
    }
    private static Singleton uniqueInstance =new Singleton();;

    public static  Singleton getUniqueInstance (){
        return uniqueInstance;
    }

}

3.静态内部类实现

当 Singleton 类加载时,静态内部类 SingletonHolder 没有被加载进内存。只有当调用 getUniqueInstance() 方法从而触发 SingletonHolder.INSTANCE 时 SingletonHolder 才会被加载,此时初始化 INSTANCE 实例。 这种方式不仅具有延迟初始化的好处,而且由虚拟机提供了对线程安全的支持

public class Singleton {

    private Singleton() {
    }

    private static class SingletonHolder {
        private static final Singleton INSTANCE = new Singleton();
    }

    public static Singleton getUniqueInstance() {
        return SingletonHolder.INSTANCE;
    }
}

4.枚举实现

这是单例模式的最佳实践,它实现简单,并且在面对复杂的序列化或者反射攻击的时候,能够防止实例化多次

public enum Singleton {
    uniqueInstance;
}
欢迎使用“可调增益放大器 Multisim”设计资源包!本资源专为电子爱好者、学生以及工程师设计,旨在展示如何在著名的电路仿真软件Multisim环境下,实现一个具有创新性的数字控制增益放大器项目。 项目概述 在这个项目中,我们通过巧妙结合模拟电路与数字逻辑,设计出一款独特且实用的放大器。该放大器的特点在于其增益可以被精确调控,并非固定不变。用户可以通过控制键,轻松地改变放大器的增益状态,使其在1到8倍之间平滑切换。每一步增益的变化都直观地通过LED数码管显示出来,为观察和调试提供了极大的便利。 技术特点 数字控制: 使用数字输入来调整模拟放大器的增益,展示了数字信号对模拟电路控制的应用。 动态增益调整: 放大器支持8级增益调节(1x至8x),满足不同应用场景的需求。 可视化的增益指示: 利用LED数码管实时显示当前的放大倍数,增强项目的交互性和实用性。 Multisim仿真环境: 所有设计均在Multisim中完成,确保了设计的仿真准确性和学习的便捷性。 使用指南 软件准备: 确保您的计算机上已安装最新版本的Multisim软件。 打开项目: 导入提供的Multisim项目文件,开始查看或修改设计。 仿真体验: 在仿真模式下测试放大器的功能,观察增益变化及LED显示是否符合预期。 实验与调整: 根据需要调整电路参数以优化性能。 实物搭建 (选做): 参考设计图,在真实硬件上复现实验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值