线程中的AtomicInteger和CountDownLatch
来源:互联网 发布:电脑看电视直播软件 编辑:程序博客网 时间:2024/06/05 10:27
1、AtomicInteger
使用AtomicInteger,即使不用同步块synchronized,也可以保证Integer类原子性操作,因为i++;++i并不是线程安全的
//获取当前的值
public final int get()
//取当前的值,并设置新的值
public final int getAndSet(int newValue)
//获取当前的值,并自增
public final int getAndIncrement()
//获取当前的值,并自减
public final int getAndDecrement()
//获取当前的值,并加上预期的值
public final int getAndAdd(int delta)
2、CountDownLatch
一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。用给定的计数 初始化 CountDownLatch。由于调用了 countDown() 方法,所以在当前计数到达零之前,await 方法会一直受阻塞。之后,会释放所有等待的线程,await 的所有后续调用都将立即返回。这种现象只出现一次——计数无法被重置。 一个线程(或者多个), 等待另外N个线程完成某个事情之后才能执行
public class TestThread {public static AtomicInteger count = new AtomicInteger(0);public static void main(String[] args) throws InterruptedException { //java中的辅助类,可以保证 final CountDownLatch latch = new CountDownLatch(1000); for (int i = 0; i < 1000; i++) { new Thread(new Runnable() { @Override public void run() { count.getAndIncrement(); latch.countDown(); } }).start(); }latch.await();System.out.println(count.get());}}
0 0
- 线程中的AtomicInteger和CountDownLatch
- 线程通信中的CountDownLatch和CycliBarrier
- java 线程 新类库中的构件 countDownLatch 使用
- Java中的CyclicBarrier和CountDownLatch
- Java中的线程(十一)- AtomicInteger的用法
- 线程CountDownLatch
- 使用CountDownLatch启动和停止线程
- 用CountDownLatch和CyclicBarrier处理并发线程
- Java线程学习笔记CountDownLatch 和CyclicBarrier
- 线程通信——CountDownLatch和CyclicBarrier
- JAVA 中无锁的线程安全整数 AtomicInteger介绍和使用
- JAVA中无锁的线程安全整数AtomicInteger介绍和使用
- 并发编程中的CountDownLatch和CyclicBarrier
- Java SE5中的CountDownLatch和CyclicBarrier类库
- java 线程原子问题 AtomicInteger
- AtomicInteger线程安全的i++
- Java线程之三 AtomicInteger
- AtomicInteger理解和使用
- Windows下使用WxWidgets库时需要额外链接的Windows静态库
- D3D网格(一)
- SPring MVC 表单校验
- HDU 2156 分数矩阵
- Mandelbrot集
- 线程中的AtomicInteger和CountDownLatch
- HDU 1283最简单的计算机
- 深入理解HTTP协议
- Java 中的成员内部类
- Git把Tag推送到远程仓库
- Activity内部Handler引起内存泄露的原因分析
- stack和queue常用方法
- 分形理论
- 你好,Rust!