zoukankan      html  css  js  c++  java
  • 多线程之整体概括

    13.Java并发:多线程和java.util.concurrent并发包总结

    12.多线程的体系

    11.Java中锁的分类及概念

    =====

     

    13.Java并发:多线程和java.util.concurrent并发包总结

    引言

    前面已经针对Java多线程框架中具体的点介绍了很多了,现在是需要一个概括性总结的时候了,正好从网上找到一张描述java.util.concurrent包组成结构的类图,正好可以对java多线程中并发这块有一个概览性总结。

    在转载别人的图之前先简要总结一下:

    一、描述线程的类:Runable和Thread都属于java.lang包

    二、内置锁synchronized属于jvm关键字,内置条件队列操作接口Object.wait()/notify()/notifyAll()属于java.lang包

    二、提供内存可见性和防止指令重排的volatile属于jvm关键字

    四、而java.util.concurrent包(J.U.C)中包含的是java并发编程中有用的一些工具类,包括几个部分:

    1、locks部分:包含在java.util.concurrent.locks包中,提供显式锁(互斥锁和速写锁)相关功能;

    2、atomic部分:包含在java.util.concurrent.atomic包中,提供原子变量类相关的功能,是构建非阻塞算法的基础;

    3、executor部分:散落在java.util.concurrent包中,提供线程池相关的功能;

    4、collections部分:散落在java.util.concurrent包中,提供并发容器相关功能;

    5、tools部分:散落在java.util.concurrent包中,提供同步工具类,如信号量、闭锁、栅栏等功能;

    以下图片转自:这里,文章标题是:深入浅出 Java Concurrency (1) : J.U.C的整体认识

    再次感谢画这张图的作者。

     

    12.多线程体系

    图片来源:https://yq.aliyun.com/articles/61960?utm_campaign=wenzhang&utm_medium=article&utm_source=QQ-qun&utm_content=m_10571

    11.Java中锁的分类及概念

    file

    • 线程要不要锁住同步资源
      • 悲观锁,又叫互斥同步锁【锁住同步资源】
      • 乐观锁,又叫非互斥同步锁【不锁住同步资源】
    • 多线程能否共享一把锁
      • 共享锁,又叫读锁【多线程可共享一把锁】
      • 独占锁,又叫写锁【多线程不可共享一把锁】
    • 多线程等锁竞争时,是否需要排队
      • 公平锁【需要排队,先排队的先拿到锁】
      • 非公平锁【不需要排队,先尝试插队、失败再排队】
    • 同一个线程是否可以重复获取同一把锁
      • 可重入锁【同一个线程可以重复获取同一把锁】
      • 不可重入锁【同一线程不可一重复拿到同一把锁,即同一线程拿锁也要等到之前的锁释放】
    • 是否可以中断操作
      • 可中断锁【等待锁时可以中断】
      • 非可中断锁【等待锁时不可以中断】
    • 等到的过程、方式
      • 自旋锁【自旋尝试获取锁】
      • 非自旋锁【阻塞等待获取锁】
     
  • 相关阅读:
    斐波那契数列
    进制转换为伪代码
    python模拟进程
    第十一周学习总结
    第十周学习总结
    第九周学习总结
    俄罗斯方块
    熟悉编程语言
    小学四则运算
    第八周学习总结
  • 原文地址:https://www.cnblogs.com/awkflf11/p/9206246.html
Copyright © 2011-2022 走看看