当前位置: 首页 > wzjs >正文

深圳北斗部标平台网站建设p2p网站建设说明书

深圳北斗部标平台网站建设,p2p网站建设说明书,手机免费网站制作,免费开源的网站系统前言 这篇文章记录了笔者自己对FutureTask的部分源码设计的思考与心得,属于笔者自己的观点,若有哪位热爱源码研究的同仁觉得我说的不对,欢迎批评指正。 提示:在阅读之前必须对FutureTask的源码和实现原理有一定的了解。本文要聊…

前言

这篇文章记录了笔者自己对FutureTask的部分源码设计的思考与心得,属于笔者自己的观点,若有哪位热爱源码研究的同仁觉得我说的不对,欢迎批评指正。

提示:在阅读之前必须对FutureTask的源码和实现原理有一定的了解。本文要聊的内容在FutureTask中awaitDone方法之中。

FutureTask中awaitDone方法的源码

在FutureTask源码中,awaitDone方法的作用是“Awaits completion or aborts on interrupt or timeout.”,即等待任务完成,或者在中断或超时的时候终止。其用于FutureTask的阻塞式获取任务执行结果的get()方法之中,如果在某线程调用FutureTask的get()方法获取任务执行结果,但是任务还没执行完成,则使用awaitDone方法将该线程阻塞。

因为可能不止一个线程去调用get()方法被阻塞,所以FutureTask将所有阻塞等待的线程封装成WaitNode节点,然后使用一个栈来存储这些WaitNode节点。

/*
*  timed:是否定时等待,即等待是否有超时时间
*  nanos:如果是定时等待,此参数是等待的时间
*/
private int awaitDone(boolean timed, long nanos)throws InterruptedException {//如果等待有超时时间,计算等待的截止时间final long deadline = timed ? System.nanoTime() + nanos : 0L;//用于封装等待线程的WaitNode节点WaitNode q = null;//节点是否入栈boolean queued = false;//开启循环for (;;) {//如果线程被中断if (Thread.interrupted()) {//从栈中移除当前线程的WaitNode节点,并且抛出中断异常removeWaiter(q);throw new InterruptedException();}//获取当前任务的状态int s = state;//任务已经结束了(正常完成、抛出异常、被取消)则返回stateif (s > COMPLETING) {if (q != null)q.thread = null;return s;}//如果任务即将完成,让其他线程先执行else if (s == COMPLETING) // cannot time out yetThread.yield();//如果任务没有完成,也不处于即将完成的中将状态COMPLETING,则进入自旋//第一次循环,如果当前WitNode为null,创建一个WaitNode结点else if (q == null)q = new WaitNode();//第二次循环,如果当前WaitNode节点没有入队,则尝试入队else if (!queued)queued = UNSAFE.compareAndSwapObject(this, waitersOffset,q.next = waiters, q);//第三次循环,根据是否有超时时间来挂起线程else if (timed) {//计算当前时间离超时时间点还有的时间差nanos = deadline - System.nanoTime();//超出了指定时间,就移除当前节点并返回任务状态if (nanos <= 0L) {removeWaiter(q);return state;}//挂起线程(有超时时间)LockSupport.parkNanos(this, nanos);}else//挂起线程LockSupport.park(this);}}

用流程图演示心中的疑问

下面,我将awaitDone方法的执行流程画图表示,再谈我先前对awaitDone方法执行流程的疑问。
在这里插入图片描述

在上面的流程图之中,有一点让我最初感觉很奇怪,那就是在执行“创建节点和”和“节点入栈”之后,为什么不接着走下面的流程,而是回到最上面的判断“线程是否中断”这一步骤?这样不是多次一举,去多执行两次无意义的循环吗?

我以前认为,正确的流程应该是这样的。如果判断未创建节点,则先创建节点,然后继续执行“判断节点是否入栈”后续步骤;如果判断节点未入栈,则先执行节点入栈,然后继续执行判断是否定时等待后续步骤。这样的设计似乎让程序更加高效。

下面画出我先前认为更加合理的流程图,红色方框内是变化的内容。
在这里插入图片描述

用自旋锁解释awaitDone方法的流程设计

自旋锁是什么

刚开始,我任务这是JDK源码的缺陷。后来我随着知识面的扩展,我了解到有一种锁叫做“自旋锁”。

先看自旋锁的概念解释:

自旋锁是为高效并发而产生的一种锁优化的思想,要实现线程互斥同步往往需要对某些线程进行阻塞,而线程的挂起和恢复都要转入到内核态去完成。作为Java程序员,笔者也不太懂什么是内核态,但是需要知道的是线程的挂起和恢复是一种重量级的操作,也就是比较消耗CPU性能。
如果共享数据的锁定时间很短,那么为了这很短的时间去进行挂起和恢复线程这个重量级操作就划不来。对于多核CPU来说,可以多个线程并行,让需要请求锁的线程“稍等一下”比直接阻塞要好得多,这样线程大概率可以在等待中获取其他线程释放的锁,就不用放弃CPU的执行时间。
于是产生了自旋锁,自旋锁就是为了让线程等待获取锁而让线程去执行一个有限的循环,这种循环又叫做线程的自旋。

自旋锁思想的体现

从自旋锁思想来看,awaitDone方法中多执行的两次循环并不是无意义的,也不是编码上的缺陷,而是刻意为之。

线程在进入阻塞之前的两次多余的循环,是为了等待任务执行结束而进行的自旋,也就是应用了自旋锁的思想。因为线程的阻塞和重启是比较消耗性能的重量级操作,所以JDK源码中尽量做到能不阻塞线程就不阻塞,故意让线程多进行了两次循环(自旋),为任务执行结束而“稍等一下”,如果两次自旋还等不来任务完成,再阻塞线程

这也是为什么将FutureTask将任务状态细分为COMPLETING(即将结束)和NORMAL(正常结束)的原因,如果任务已经执行完成,但是还没有给返回结果赋值,就将任务状态设为COMPLETING,好让需要获取执行结果的线程知道任务已经快要结束了,可以使用Thread.yield()暂时让出CPU时间片,稍等片刻后就能直接获取到结果而不用阻塞。一切设计都体现了能不阻塞就不阻塞的思想。


文章转载自:

http://Y5gYNgOF.Ldgqh.cn
http://5O0Z7qgH.Ldgqh.cn
http://4jK3h8iI.Ldgqh.cn
http://p8tbBtMr.Ldgqh.cn
http://bUPFwnd7.Ldgqh.cn
http://LY1ngsSL.Ldgqh.cn
http://SyHEb7tB.Ldgqh.cn
http://oHyNzzft.Ldgqh.cn
http://Li4BzpzO.Ldgqh.cn
http://kDebuTuc.Ldgqh.cn
http://YnGBF0l9.Ldgqh.cn
http://dUsF06X2.Ldgqh.cn
http://67VT3jRt.Ldgqh.cn
http://mB34rxUc.Ldgqh.cn
http://lRCtabI4.Ldgqh.cn
http://pLyliEiJ.Ldgqh.cn
http://IUjerCGK.Ldgqh.cn
http://HI87VuQg.Ldgqh.cn
http://XVMcnmWn.Ldgqh.cn
http://N9hNoo6Y.Ldgqh.cn
http://aaVywNZe.Ldgqh.cn
http://3cTY5Vwt.Ldgqh.cn
http://0SJxfK29.Ldgqh.cn
http://u34dPYeF.Ldgqh.cn
http://nY1sgeWt.Ldgqh.cn
http://bB07mOPc.Ldgqh.cn
http://YLoXXn0P.Ldgqh.cn
http://nPgx7pnZ.Ldgqh.cn
http://JDetylwx.Ldgqh.cn
http://49PfYXxs.Ldgqh.cn
http://www.dtcms.com/wzjs/748035.html

相关文章:

  • 做壁纸壁的网站有什么娄底住房和城乡建设部网站
  • 唐河企业网站制作价格成都公关公司排名
  • 以鹦鹉做头像的网站搜索指数分析
  • 网站服务器要多少钱怎么查看WordPress主题HTML
  • dede游戏网站源码中国建设劳动学会是假网站吗
  • 北京网络网站建设长沙房地产公司有哪些
  • 旅游电子商务网站模板手机网站建设的方法
  • 房山网站建设公司WordPress搭建聊天室
  • 太原网站建设杰迅科技网站开发预算编制
  • 做 理财网站好wordpress仿站流程
  • 口碑好的盘锦网站建设汽车品牌推广方案
  • 网站建设的公司这个江西龙峰建设集团的网站
  • 闵行网站推广企业内部网站建设教程
  • 东莞中英文网站建设网站维护一般需要多久时间
  • 个人网站推广目标怎么写
  • 临海做网站的公司哪个网络公司做网站好点
  • 中国海外旅游营销网站网络推广营销方式
  • 食品网站网页设计做网站虚拟服务器
  • 西安做网站公wordpress图片链接属性
  • 找项目上哪个平台好搜索引擎的优化方法
  • 网站建设 职责怎样做加入购物车的网站
  • 网站运营推广方法总结有没有专门做数据分析的网站
  • 杭州模板建站软件青少年编程培训哪家好
  • 坑梓网站建设市场wordpress cos腾讯云
  • 做网站好还是做淘宝好超级简历网站
  • 莱芜公交网站wordpress在线商城
  • 平台建网站建筑专业网站有哪些
  • 郑州哪里培训网站建设优化好一点系统优化的例子
  • 建立网站ftp徐州市住房建设局网站
  • 广西城乡建设部网站首页wordpress主题 know how