Java并发数据一致性需依场景选同步机制:synchronized控临界区,volatile保可见性非原子性,Concurrent包提高效线程安全组件,CAS适用低冲突场景但有ABA等问题。
Java中保证并发下的数据一致性,核心在于控制多个线程对共享资源的访问顺序与可见性。不是简单加锁就能解决,关键要看场景:是读多写少?是否涉及复合操作?有没有跨多个变量的逻辑一致性?选对同步机制比盲目用synchronized更重要。
synchronized是最基础也最常用的同步手段,它能确保同一时刻只有一个线程执行被修饰的代码块或方法。注意它锁定的是对象(实例方法锁this,静态方法锁Class对象),不是代码本身。
volatile关键字保证变量的修改对所有线程立即可见,并禁止指令重排序,但它不能保证复合操作的原子性。比如i++(读-改-写三步)即使i是volatile,依然可能出错。
简化并发控制JDK提供的并发包封装了大量经过验证的线程安全组件,比手写同步更可靠、更高效。
基于CAS(Compare-And-Swap)的原子类和AQS框架是Java并发的底层支柱。但CAS不是银弹——存在ABA问题、循环时间长导致CPU占用高、只能保证单变量原子性等问题。
不复杂但容易忽略的是:一致性不只是线程安全,还包括事务边界、缓存一致性、分布式场景下的最终一致等延伸问题。本地并发控制只是第一步。