zoukankan      html  css  js  c++  java
  • JAVA并发编程的艺术

    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、两个线程之间有同步点,用于在同步点上进行数据交换。

             

           

  • 相关阅读:
    MS SQL 数据库状态为SUSPECT(可疑)的处理方法
    根據名稱查找文件,并移動
    deploy war to weblogic via script(shell)
    maven打包时包含所有依赖的jar
    随笔
    如何在Oracle SQL Developer對Procedure除錯
    git常用命令和記錄
    英語筆記
    IDEA設置
    mysql常用命令和记录
  • 原文地址:https://www.cnblogs.com/YDDMAX/p/5641891.html
Copyright © 2011-2022 走看看