JAVA多线程并发下的单例模式应用

您所在的位置:网站首页 java实现构造函数 JAVA多线程并发下的单例模式应用

JAVA多线程并发下的单例模式应用

2023-04-07 00:34| 来源: 网络整理| 查看: 265

单例模式应该是设计模式中比较简单的一个,也是非常常见的,但是在多线程并发的环境下使用却是不那么简单了,今天给大家分享一个我在开发过程中遇到的单例模式的应用。

首先我们先来看一下单例模式的定义:

一个类有且仅有一个实例,并且自行实例化向整个系统提供。 单例模式的要素: 1.私有的静态的实例对象 2.私有的构造函数(保证在该类外部,无法通过new的方式来创建对象实例) 3.公有的、静态的、访问该实例对象的方法

单例模式分为懒汉形和饿汉式

懒汉式:

应用刚启动的时候,并不创建实例,当外部调用该类的实例或者该类实例方法的时候,才创建该类的实例。(时间换空间)

优点:实例在被使用的时候才被创建,可以节省系统资源,体现了延迟加载的思想。

缺点:由于系统刚启动时且未被外部调用时,实例没有创建;如果一时间有多个线程同时调用LazySingleton.getLazyInstance()方法很有可能会产生多个实例。

例子:

publicclassSingletonClass{ //私有构造函数,保证类不能通过new创建 privateSingletonClass(){} privatestaticSingletonClassinstance=null; publicstaticSingletonClassgetInstance(){ if(instance==null){ //创建本类对象 instance=newSingletonClass(); } returninstance; } }

饿汉式:

应用刚启动的时候,不管外部有没有调用该类的实例方法,该类的实例就已经创建好了。(空间换时间。)

优点:写法简单,在多线程下也能保证单例实例的唯一性,不用同步,运行效率高。

缺点:在外部没有使用到该类的时候,该类的实例就创建了,若该类实例的创建比较消耗系统资源,并且外部一直没有调用该实例,那么这部分的系统资源的消耗是没有意义的。

例子:

publicclassSingleton{ //首先自己在内部定义自己的一个实例,只供内部调用 privatestaticfinalSingletoninstance=newSingleton(); //私有构造函数 privateSingleton(){ } //提供了静态方法,外部可以直接调用 publicstaticSingletongetInstance(){ returninstance; } } 下面模拟单例模式在多线程下会出现的问题 /** *懒汉式单例类 */ publicclassLazySingleton{ //为了易于模拟多线程下,懒汉式出现的问题,我们在创建实例的构造函数里面使当前线程暂停了50毫秒 privateLazySingleton(){ try{ Thread.sleep(50); }catch(InterruptedExceptione){ e.printStackTrace(); } System.out.println("生成LazySingleton实例一次!"); } privatestaticLazySingletonlazyInstance=null; publicstaticLazySingletongetLazyInstance(){ if(lazyInstance==null){ lazyInstance=newLazySingleton(); } returnlazyInstance; } }

测试代码:我们在测试代码里面新建了10个线程,让这10个线程同时调用LazySingleton.getLazyInstance()方法

publicclassSingletonTest{ publicstaticvoidmain(String[]args){ //创建十个线程调 for(inti=0;i


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3