写了一个系列的文章--JUC 框架源码解析系列文章

2021-01-11 21:34:30 +08:00
 amiwrong123

来 v 站也一年多了,很喜欢与 v 友们交流技术,只是很后悔没有早点来 v 站(工作后才知道 v 站),要是早点来,可能我的路子会走得更好(话题扯远了)。

去年有段时间对 JUC 框架很感兴趣,就花了几个月时间来阅读了它们的源码。期间也是来过 v 站发过很多帖子来询问。

本人属于比较笨的那种,一个概念如果不是由浅入深、循序渐进的方式讲解就可能搞不懂,所以我写的博客也会很具体,很多细节会去看,所以我觉得我的博客也会比较好懂(王婆卖瓜~)。

写完这个系列确实收获很大,唯一的遗憾是没有时间去看 forkjoinpool 的源码了。在这里把文章分享给大家,希望和大家多多交流。尤其对 AQS 讲解得很细致,把 AQS 分为了四部分循序渐进得进行了讲解(之前也看了这位大佬的博客 https://segmentfault.com/a/1190000016058789 ,他写的很好,对我启发很大,也向大家推荐)。

大家也不要吐槽我在 csdn 写博客哈。下面放干货:

JUC 框架 源码解析系列文章目录 JDK8

JUC 框架的基础是 CAS 和自旋,而 CAS 则是利用Unsafe类提供的 CAS 操作,而原子类则依靠于 CAS 和自旋。下面几篇文章从源码分析 JUC 框架内的几个重要的原子类。

ThreadLocal 本身不在 JUC 框架之中,但它却是一种防止多线程竞争的重要手段。

AQS ( AbstractQueuedSynchronizer )向下依赖了 CAS 和自旋,向上则提供了一个同步队列的实现,许多 JUC 框架内中的类都直接使用了 AQS 作为内部类。下面几篇文章将从 AQS 提供的几种功能进行深度分析。

AQS 中有些函数的具体实现细节,并不是很容易让人理解,这些地方一般都是因为考虑了同步队列变化中的中间状态。

JUC 框架中有些同步构件依赖了 AQS 作为实现底层,我们一般使用它们来做到多线程之间的协作。

JUC 框架中也提供了各种用途的集合类。

最后部分将讲解线程池相关源码。

PS:如果看了觉得真有帮助,可以帮忙投个票吗,https://bss.csdn.net/m/topic/blog_star2020/detail?username=anlian523

2425 次点击
所在节点    程序员
6 条回复
yaocai321
2021-01-11 23:07:01 +08:00
给你一个大大的赞~
sprit
2021-01-12 09:15:02 +08:00
爱了爱了
zifangsky
2021-01-12 09:58:18 +08:00
简单看了一篇,看起来写得挺好的,后续有时间会好好拜读你的文章。另外,已经给你投票了。
zyfsuzy
2021-01-12 10:27:59 +08:00
可以
yamasa
2021-01-12 11:18:10 +08:00
支持支持
fangcan
2021-01-12 15:33:03 +08:00
还没具体看内容,看帖子感觉不错 支持

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/743989

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX