JAVA并发编程的艺术
2016-07-04 22:18
288 查看
CAS有两个特点:
1、for循环
2、compareAndSet(可能别的线程先改变然后又重置,此时CAS是成功的,也就是CAS执行的过程中,可能多个线程对此变量做了修改,而不是各个线程互斥的修改)
3、CAS和互斥锁不同,CAS可以多个线程同时执行成功。
Thread.join()
下面是源码。A.jonin(B),所以当B结束的时候会notifyA,怎么实现的?实现是在JVM里面,需要看JVM源码
Thread.join()
while(t.isAlive()){
wait(0);
}
七、JAVA中的13个原子类
原子操作类提供了一种用法简单,性能高效(为什么高效),线程安全的更新一个变量的方式
核心:循环CAS,底层使用的是Unsafe类
八、JAVA中的并发工具类(提供超时等重载方法,含有查询线程排队和统计的接口)
1、CountDownLatch
1、不能重复使用
2、相当于Thread.join()
3、调用countdown方法happens-before,另外一个线程调用await方法。
2、CyclicBarrier
1、可以用于多个线程计算数据,最后合并计算结果的场景。
2、合并计算结果的线程是最后await的那个线程。
3、可以在await的过程中reset,重置计数器
4、可以查询是否有await的线程broken
3、Semaphore
1、 用于控制访问某个资源的线程数
4、Exchange
1、用于线程间的数据交换。
2、两个线程之间有同步点,用于在同步点上进行数据交换。
1、for循环
2、compareAndSet(可能别的线程先改变然后又重置,此时CAS是成功的,也就是CAS执行的过程中,可能多个线程对此变量做了修改,而不是各个线程互斥的修改)
3、CAS和互斥锁不同,CAS可以多个线程同时执行成功。
Thread.join()
下面是源码。A.jonin(B),所以当B结束的时候会notifyA,怎么实现的?实现是在JVM里面,需要看JVM源码
Thread.join()
while(t.isAlive()){
wait(0);
}
七、JAVA中的13个原子类
原子操作类提供了一种用法简单,性能高效(为什么高效),线程安全的更新一个变量的方式
核心:循环CAS,底层使用的是Unsafe类
八、JAVA中的并发工具类(提供超时等重载方法,含有查询线程排队和统计的接口)
1、CountDownLatch
1、不能重复使用
2、相当于Thread.join()
3、调用countdown方法happens-before,另外一个线程调用await方法。
2、CyclicBarrier
1、可以用于多个线程计算数据,最后合并计算结果的场景。
2、合并计算结果的线程是最后await的那个线程。
3、可以在await的过程中reset,重置计数器
4、可以查询是否有await的线程broken
3、Semaphore
1、 用于控制访问某个资源的线程数
4、Exchange
1、用于线程间的数据交换。
2、两个线程之间有同步点,用于在同步点上进行数据交换。
相关文章推荐
- java/对象数组/集合
- java锁机制
- spring aop 执行两次
- Java反射机制
- jdk-logging、log4j、logback日志介绍及原理一
- java实现栈
- [JAVA]运用反射机制,抛出的异常的捕获方法
- java学习中的部分注解
- Java Classloader机制解析
- 初来报道,自我介绍!求老司机带路,助我入门!
- Eclipse部分操作总结
- 【MyEclipse】——MyEclipse has detected that less than 5% of the 28M of PS Survivor Space...
- 多线程-CountDownLatch应用
- java程序启动界面
- Java正则
- Java中的ReentrantLock和synchronized两种锁定机制的对比
- Java开发必用的工具包
- Spring工作原理
- 算法之 排序算法 (二) Java
- 多线程-join的应用