码迷,mamicode.com
首页 > 编程语言 > 详细

JAVA并发编程的艺术

时间:2016-07-04 23:34:29      阅读:240      评论:0      收藏:0      [点我收藏+]

标签:

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中的并发工具类(提供超时等重载方法,含有查询线程排队和统计的接口)

    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并发编程的艺术

标签:

原文地址:http://www.cnblogs.com/YDDMAX/p/5641891.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!