java单例模式并解决懒汉式下线程不安全的问题

本文深入探讨了单例模式中的懒汉式与饿汉式的概念,分析了懒汉式在多线程环境下可能引发的线程安全问题,并通过实例演示如何使用多线程实现饿汉式单例模式,确保线程安全。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

其中,懒汉式是线程不安全的,当有多条线程同时访问单例对象时,则会出现多线程临界资源问题。
现在用多线程实现并解决线程安全问题

饿汉式

public class SigletonDemo01 {
       static HashSet<King> hs = new HashSet<>();
       static Runnable r = new Runnable() {
	@Override
		public void run() {
		//获取单例对象
		King king = King.currentInstance();
		//将获取到的单例对象添加到集合中
		hs.add(king);
		}
	};
		public static void main(String[] args) {
		//需求:多条线程同时去获取单例对象,然后将获取到的单例对象添加到HashSet中
		//创建多个线程对象,同时访问 单例对象
		for (int i = 0; i < 10000; i++) {
		Thread thread = new Thread(r);
		thread.start();
		}
		System.out.println(hs);
		}
	}

懒汉式

public class SigletonDemo02 {
	    static HashSet<Queue> hs = new HashSet<>();
	    static Runnable r = new Runnable() {
		@Override
		public void run() {
			// 获取单例对象
			Queue king = Queue.currentInstance();
			// 将获取到的单例对象添加到集合中
			hs.add(king);
			}
		};
		public static void main(String[] args) {
			// 创建多个线程对象,同时访问 单例对象
			for (int i = 0; i < 1000; i++) {
			     Thread thread = new Thread(r);
			     thread.start();
			}
			System.out.println(hs);
		}
	}
	class Queue {
		private static Queue instance;
		private Queue() {
		}
		//使用同步代码块,同步方法,以及同步锁都可以解决
		public synchronized static Queue currentInstance() {
			if (instance == null) {
			instance = new Queue();
		}
		return instance;
		}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值