使用原子类进行i++操作
除了在i++操作时使用synchronized关键字实现同步外,还可以使用AtomicInteger原子类进行实现。
原子操作是不能分割的整体,没有其他线程能够中断或检查正在原子操作中的变量。一个原子类型(atomic)就是一个原子操作可用的类型,它可以在没有锁的情况下做到线程安全。
文件AddCountThread.java代码如下:
package com.example.demo;
import java.util.concurrent.atomic.AtomicInteger;
public class AddCountThread extends Thread {
private AtomicInteger count = new AtomicInteger(0);
@Override
public void run() {
for (int i = 0; i < 10000; i++) {
System.out.println(count.incrementAndGet());
}
}
}
文件Run.java代码如下:
package com.example.demo;
imp

本文探讨了如何在Java多线程环境中使用AtomicInteger原子类替代synchronized关键字进行i++操作。虽然原子类提供了线程安全的保证,但其方法间的调用并非原子性的,仍可能需要同步来确保整体逻辑的线程安全。
订阅专栏 解锁全文
1102

被折叠的 条评论
为什么被折叠?



