使用 synchronized 关键字可实现线程安全计数器,通过对象锁保证 increment 和 getCount 方法的互斥访问;2. AtomicInteger 基于 CAS 实现无锁操作,适合高并发场景,性能优于 synchronized;3. ReentrantLock 提供更灵活的锁机制,支持公平锁和可中断等待,适用于复杂控制需求;4. 选择方案应根据具体场景:简单同步用 synchronized,高性能需求选 AtomicInteger,需高级特性时用 ReentrantLock,关键在于确保所有共享状态访问均受同步保护。

在多线程环境下,共享变量如计数器容易出现并发问题。Java提供了多种方式来创建线程安全的计数器,确保多个线程同时访问时数据的一致性和正确性。
使用 synchronized 关键字
最直接的方式是通过 synchronized 保证方法或代码块的互斥访问。
示例:
public class SynchronizedCounter { private int count = 0; public synchronized void increment() { count++; } public synchronized int getCount() { return count; }}
每次调用 increment() 或 getCount() 都会获取对象锁,防止多个线程同时修改或读取值。
使用 AtomicInteger 类
Java 提供了 java.util.concurrent.atomic.AtomicInteger,基于 CAS(Compare-And-Swap)实现无锁线程安全操作,性能通常优于 synchronized。
立即学习“Java免费学习笔记(深入)”;
Poixe AI
统一的 LLM API 服务平台,访问各种免费大模型
75 查看详情
示例:
import java.util.concurrent.atomic.AtomicInteger;public class AtomicCounter { private AtomicInteger count = new AtomicInteger(0); public void increment() { count.incrementAndGet(); // 原子自增 } public int getCount() { return count.get(); }}
AtomicInteger 适合高并发场景,避免了加锁带来的性能开销。
使用显式锁(ReentrantLock)
如果需要更灵活的锁控制,可以使用 ReentrantLock 替代 synchronized。
示例:
import java.util.concurrent.locks.ReentrantLock;public class LockedCounter { private int count = 0; private final ReentrantLock lock = new ReentrantLock(); public void increment() { lock.lock(); try { count++; } finally { lock.unlock(); } } public int getCount() { lock.lock(); try { return count; } finally { lock.unlock(); } }}
这种方式支持公平锁、可中断等待等高级特性,但代码略显冗长。
基本上就这些。选择哪种方式取决于具体需求:简单场景用 synchronized,高并发推荐 AtomicInteger,复杂控制可用 ReentrantLock。关键是确保所有访问共享状态的操作都受到同步保护。
以上就是如何在Java中创建线程安全的计数器的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/728087.html
微信扫一扫
支付宝扫一扫