单例模式(Singleton)

本文详细介绍了单例模式的两种实现方式:饿汉式和懒汉式,并深入探讨了懒汉式单例在多线程环境下的安全性问题及其解决办法。
  1. //饿汉式单例
    public class HungerSingleton {
     //类加载时直接创建实例
     private static HungerSingleton instance = new HungerSingleton();
     
     private HungerSingleton(){
      
     }
     
     public static HungerSingleton getInstance(){
      return instance;
     }
    }
      
  2. 懒汉式单例
    public class LazySingleton {
      
     private static LazySingleton instance = null;
        private LazySingleton(){
       
        }
        public static LazySingleton getInstance(){
         if (instance == null) {
       instance = new LazySingleton();
         }
         return instance;
        }
    }
    懒汉式单例在单线程下是安全的,但是在多线程下可能会是非安全的
    1.Thread1 if(instance=null)为true且Thread2 if(instance=null)也为true
    这时会创建两个实例,改进方法就是加上(synchronized)同步机制:
    public class LazySingleton {
      
     private static LazySingleton instance = null;
        private LazySingleton(){
       
        }
        public static synchronized LazySingleton getInstance(){
         if (instance == null) {
       instance = new LazySingleton();
         }
         return instance;
        }
    }
    上例中同步机制能防止多线程下的非安全,但是会降低系统的效率,在服务器上为了顾及Singleton、Lazy Initialization与效能问题
      因而有了(双重检索锁定)Double-check Locking的模式,代码如下:
     
    public class LazySingleton{
     private static LazySingleton instance = null;
     private LazySingleton(){
      
     }
     public static LazySingleton getInstance(){
      if(instance==null){
       //只有在第一次建立实例时才会进入同步区,之后由于实例已建立,也就不用进入同步区进行锁定。
       synchronized (LazySingleton.class){
        if (instance==null) {
         instance =new LazySingleton();
        }
       }
      }
      return instance;
     }
    }
    鉴于当前的内存模型的原因,该习语尚未得到广泛使用,就明显成为了一种不安全的编程结构。重定义脆弱的内存模型这一领域的工作正在进行中。尽管如此,即使是在新提议的内存模型中,双重检查锁定也是无效的。对此问题最佳的解决方案是接受同步或者使用一个 static field。
    参考http://www.ibm.com/developerworks/cn/java/j-dcl.html
先展示下效果 https://pan.quark.cn/s/e81b877737c1 Node.js 是一种基于 Chrome V8 引擎的 JavaScript 执行环境,它使开发者能够在服务器端执行 JavaScript 编程,显著促进了全栈开发的应用普及。 在 Node.js 的开发流程中,`node_modules` 文件夹用于存储所有依赖的模块,随着项目的进展,该文件夹可能会变得异常庞大,其中包含了众多可能已不再需要的文件和文件夹,这不仅会消耗大量的硬盘空间,还可能减慢项目的加载时间。 `ModClean 2.0` 正是为了应对这一挑战而设计的工具。 `ModClean` 是一款用于清理 `node_modules` 的软件,其核心功能是移除那些不再被使用的文件和文件夹,从而确保项目的整洁性和运行效率。 `ModClean 2.0` 是此工具的改进版本,在原有功能上增加了更多特性,从而提高了清理工作的效率和精确度。 在 `ModClean 2.0` 中,用户可以设置清理规则,例如排除特定的模块或文件类型,以防止误删重要文件。 该工具通常会保留项目所依赖的核心模块,但会移除测试、文档、示例代码等非运行时必需的部分。 通过这种方式,`ModClean` 能够协助开发者优化项目结构,减少不必要的依赖,加快项目的构建速度。 使用 `ModClean` 的步骤大致如下:1. 需要先安装 `ModClean`,在项目的根目录中执行以下命令: ``` npm install modclean -g ```2. 创建配置文件 `.modcleanrc.json` 或 `.modcleanrc.js`,设定希望清理的规则。 比如,可能需要忽略 `LICENSE` 文件或整个 `docs`...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值