并发编程之AQS源码分析_第1页
并发编程之AQS源码分析_第2页
并发编程之AQS源码分析_第3页
并发编程之AQS源码分析_第4页
并发编程之AQS源码分析_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、课题,源码学院|只为培养BAT程序员而生 源码学院地址:,并发编程之AQS原理剖析 主讲老师: fox老师,线程安全问题,多线程编程中,有可能会出现多个线程同时访问同一个共享、可变资源的情况;这种资源可能是:对象、变量、文件等。由于线程执行的过程是不可控的,容易产生线程安全问题。 共享:资源可以由多个线程同时访问 可变:资源可以在其生命周期内被修改 如何解决线程安全问题: 加锁 lock sychronized 所有的并发模式在解决线程安全问题时,采用的方案都是序列化访问临界资源。,源码学院|只为培养BAT程序员而生 源码学院地址:,Synchronized和Lock,AbstractQueu

2、edSynchronizer,Java 同步器是基于AbstractQueuedSynchronizer(简称AQS)实现的,AQS是一个抽象同步框架,可以用来实现一个依赖状态的同步器 JDK中提供的大多数的同步器如Lock, Latch, Barrier等,都是基于AQS框架来实现 一般是通过一个内部类Sync继承 AQS 将同步器所有调用都映射到Sync对应的方法 AQS具备特性: 阻塞等待队列 共享/独占 公平/非公平 可重入 允许中断,源码学院|只为培养BAT程序员而生 源码学院地址:,AbstractQueuedSynchronizer,AQS内部维护属性volatile int s

3、tate state表示资源的可用状态 state三种访问方式 getState()、setState()、compareAndSetState() AQS定义两种资源共享方式 Exclusive-独占,只有一个线程能执行,如ReentrantLock Share-共享,多个线程可以同时执行,如Semaphore/CountDownLatch AQS定义两种队列 同步等待队列 条件等待队列,源码学院|只为培养BAT程序员而生 源码学院地址:,同步队列,CLH 同步队列是一个 FIFO 双向队列,AQS 依赖它来完成同步状态的管理: 当前线程如果获取同步状态失败时,AQS则会将当前线程已经等待状态等信息构造成一个节点(Node)并将其加入到CLH同步队列,同时会阻塞当前线程 当同步状态释放时,会把首节点唤醒(公平锁),使其再次尝试获取同步状态。 通过signal或signalAll将条件队列中的节点转移到同步队列。(由条件队列转化为同步队列),源码学院|只为培养BAT程序员而生 源码学院地址:,条件队列,AQS中条件队列是使用单向列表保存的,用nextWaiter来连接 调用await方法阻塞线程; 当前线程存在于同步队列的

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论