答案:基于ConcurrentLinkedQueue和AtomicInteger实现线程安全对象池,通过非阻塞队列管理对象存取,原子变量控制最大容量,确保高并发下对象获取与归还的线程安全,避免竞态条件,同时按需创建对象并限制总数,提升性能。
在Java中实现线程安全的对象池,关键在于控制多线程环境下对池中对象的获取、归还和状态管理。常见的做法是使用同步机制或并发工具类来避免竞态条件。下面介绍一种基于ConcurrentLinkedQueue和AtomicInteger的轻量级线程安全对象池实现方式。
选择线程安全的队列结构可以避免显式加锁。ConcurrentLinkedQueue是非阻塞、线程安全的队列,适合高并发场景下的对象存储与提取。
poll()方法取出一个可用对象offer()方法将其放回队列为了避免无限创建对象,需要限制池的最大容量。可以通过AtomicInteger原子地跟踪当前已创建的对象数量。
compareAndSet确保不超过最大限制public class ObjectPool{ private final ConcurrentLinkedQueue pool = new ConcurrentLinkedQueue<>(); private final AtomicInteger createdCount = new AtomicInteger(0); private final int maxSize; private final Supplier creator; public ObjectPool(Supplier creator, int maxSize) { this.creator = creator; this.maxSize = maxSize; } public T acquire() { T o bj = pool.poll(); if (obj != null) { return obj; } // 池中无可用对象,尝试创建新实例 if (createdCount.get() < maxSize) { int current; do { current = createdCount.get(); if (current >= maxSize) break; } while (!createdCount.compareAndSet(current, current + 1)); return creator.get(); } return null; // 或抛出异常/阻塞 } public void release(T obj) { if (obj != null) { // 归还前可重置对象状态 pool.offer(obj); } } }
实现线程安全对象池时还需注意以下几点:
LinkedBlockingQueue
基本上就这些。这种模式适用于数据库连接、线程、缓冲区等重量级对象的复用,能有效减少创建开销,提升系统性能。关键是保证获取和归还操作的原子性,并合理控制资源总量。不复杂但容易忽略细节。