程序员的护城河-并发编程

news/2024/5/20 5:47:39 标签: java, juc, 开发语言
  • 👏作者简介:大家好,我是爱吃芝士的土豆倪,24届校招生Java选手,很高兴认识大家
  • 📕系列专栏:Spring源码、JUC源码
  • 🔥如果感觉博主的文章还不错的话,请👍三连支持👍一下博主哦
  • 🍂博主正在努力完成2023计划中:源码溯源,一探究竟
  • 📝联系方式:nhs19990716,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬👀

文章目录

  • 前言
  • 并发编程详解
    • 感慨
    • 进程与线程
    • 线程
    • 线程常用方法及状态
    • 共享资源和线程安全性
    • synchronized底层原理
    • wait notify
    • 线程状态与ReentrantLock
    • Java内存模型
    • Java无锁模型
    • 并发编程大师的原子累加器底层优化原理(与人类的优秀灵魂对话)
    • 不可变设计
    • 手写简易版线程池思路
    • 线程池
    • ReentrantLock原理
    • 读写锁
    • ThreadLocal
    • CompletableFuture
    • 同步协作
    • 线程安全集合
    • 并发编程实践
  • 总结

前言

世间不如意十之八九。如果没办法一次到位,就分阶段实现吧。

并发编程详解

感慨

历时一个月,从一个只知道背八股的选手,到了对JAVA中常见的并发编程知识熟悉,这是一个蜕变,其实并发编程并不是一个单单的部分,当完整的学习完一个体系,就会发现,很多框架、中间件等都有并发编程的思想,比如Redis等,学会并发编程后也代表着真正的打开了走向高阶程序员的大门,这个过程注定是艰辛的,但是收获确实巨大的!!!

为此,奔着笔记和分享的原则,将整个学习体系的思考和研读整理成博客,供他人参考和指正,在此也希望能获得大家宝贵的意见,一起学习,共同进步。

进程与线程

概述进程与线程之间的关系以及简单测试多线程的好处

👉👉👉 剑指JUC原理-1.进程与线程-CSDN博客

线程

主要概述创建线程的方式以及线程运行的原理

👉👉👉 剑指JUC原理-2.线程-CSDN博客

线程常用方法及状态

本章节主要概述了JUC常见的API 以及 几种线程状态 和 其资源占用情况

👉👉👉 剑指JUC原理-3.线程常用方法及状态-CSDN博客

共享资源和线程安全性

本章节详细的介绍了线程安全性,列举多个案例来论述 共享资源读写问题、是否安全

👉👉👉 剑指JUC原理-4.共享资源和线程安全性-CSDN博客

synchronized底层原理

本章节尽可能的去讲解了synchronized 的发展流程,包括Monitor、重量级锁、轻量级锁、偏向锁、自旋优化等等。

👉👉👉 剑指JUC原理-5.synchronized底层原理-CSDN博客

wait notify

本章节主要讲解的是 关于 同步实现 和 异步实现的原理,同步实现通过观察join源码发现其实是一种保护性暂停的策略,而异步实现其实有点像消息队列的感觉,本质上就是 不管生产者传过来过,消费者不会立马消费掉,这里其实使用阻塞队列的思想就可以实现。

👉👉👉 剑指JUC原理-6.wait notify-CSDN博客

线程状态与ReentrantLock

本章节其实主要介绍了 死锁问题的发生以及如何的排查死锁,具体的可以使用jsp + jstack && top + top H + jstack && jconsloe 来排查问题,同时介绍了与synchronized 对比的一种可重入锁 ReentrantLock 的特点。

👉👉👉 剑指JUC原理-7.线程状态与ReentrantLock-CSDN博客

Java内存模型

本章节主要介绍了 Java内存模型 中的 原子性 可见性 有序性的观点,并着重的介绍了如 volatile 内存屏障的相关原理,并且以 高并发下的单例模式举例来论证 三大特性。

👉👉👉 剑指JUC原理-8.Java内存模型-CSDN博客

Java无锁模型

本章节主要介绍了 无锁模型cas具体是什么原理,以及基于cas的原子类,最终剖析了其最底层unsafe的实现,其底层是通过获取偏移量然后再进行比较。

👉👉👉 剑指JUC原理-9.Java无锁模型-CSDN博客

并发编程大师的原子累加器底层优化原理(与人类的优秀灵魂对话)

本章节主要介绍了 原子累加器 LongAdder的底层实现,其性能较好,本质上适合高并发场景的累加,分为有竞争 和 无竞争,有竞争做的优化是 创建一个累加单元数组,并发的去累加,并且针对各种逻辑进行了详细的校验。

但是有利也有弊,其性能非常好,适合高并发场景,但是精准度存在一定的问题

在这里只着重介绍一下 longadder 的 sum操作。

当我们最终获取计数器值时,我们可以使用LongAdder.longValue()方法,其内部就是使用sum方法来汇总数据的。

java.util.concurrent.atomic.LongAdder.sum():

java">public long sum() {
    Cell[] as = cells; Cell a;
    long sum = base;
    if (as != null) {
        for (int i = 0; i < as.length; ++i) {
            if ((a = as[i]) != null)
                sum += a.value;
        }
    }
    return sum;
}

实现很简单,遍历cells数组中的值,然后累加.

看上去LongAdder的性能全面超越了AtomicLong,而且阿里巴巴开发手册也提及到 推荐使用 LongAdder 对象,比 AtomicLong 性能更好(减少乐观 锁的重试次数),但是我们真的就可以舍弃掉LongAdder了吗?

当然不是,我们需要看场景来使用,如果是并发不太高的系统,使用AtomicLong可能会更好一些,而且内存需求也会小一些。

我们看过sum()方法后可以知道LongAdder在统计的时候如果有并发更新,可能导致统计的数据有误差。

而在高并发统计计数的场景下,才更适合使用LongAdder。

总结

LongAdder中最核心的思想就是利用空间来换时间,将热点value分散成一个Cell列表来承接并发的CAS,以此来提升性能。

LongAdder的原理及实现都很简单,但其设计的思想值得我们品味和学习。

👉👉👉 剑指JUC原理-10.并发编程大师的原子累加器底层优化原理(与人类的优秀灵魂对话)-CSDN博客

不可变设计

本章节主要介绍了 之所以会出现线程安全问题的原因,并结合String 中不可变设计 final 引出享元模式

👉👉👉 剑指JUC原理-11.不可变设计-CSDN博客

手写简易版线程池思路

本章节主要介绍了 一个简易版本线程池的设计思路,其本质其实就是阻塞队列,并且讲 核心线程的run方法重写,使其能够不停地复用,并且在复用的过程中还可以选择那种复用策略,是死等还是超时等待,最后再设计拒绝策略即可。

👉👉👉 剑指JUC原理-12.手写简易版线程池思路-CSDN博客

线程池

本章节主要介绍了真正的线程池,讲解了其几个核心参数 以及 FutureTask实现 和 Tomcat对线程池改造的思路。

👉👉👉 剑指JUC原理-13.线程池-CSDN博客

ReentrantLock原理

本章节首先介绍了AQS指导思想,然后又深入ReentrantLock源码去探究 公平非公平、可重入、可打断、await、signal等原理。

👉👉👉 剑指JUC原理-14.ReentrantLock原理-CSDN博客

读写锁

本章节介绍了基于ReentrantLock得读写锁,其实本质上换汤不换药,虽然分为了读写,但是只需要合理的控制state的高16位 和 低16位即可,同时在等待队列中做好新的标记,新增了shared 和 Ex标记,如果读获取到锁,还需要看看后面还有没有对应shared状态的一并解锁。

👉👉👉 剑指JUC原理-16.读写锁-CSDN博客

ThreadLocal

本章节首先介绍了ThreadLocal的基本使用场景,其次深入对应常用方法的源码,最后 针对可能存在内存泄漏的情况 以及 出现hash冲突时是怎么实现的(使用了线性探测法

👉👉👉 剑指JUC原理-15.ThreadLocal-CSDN博客

CompletableFuture

本章节主要介绍了Future的加强版 CompletableFuture 的使用,其中调用链逻辑有 后一步需要前一步、需要不需要返回值、将所有的结果整合起来等,合理的使用能够极大的提高使用效率,但是 如果使用的话,最好在get处设置超时时间,并配置 complete 返回默认值。

👉👉👉 剑指JUC原理-17.CompletableFuture-CSDN博客

同步协作

本章节主要介绍了信号量同步方面原理,其实还是基于ReentrantLock的思路进行设计,所以可见AQS思想有多么的重要了,其次还介绍了 线程协调。

👉👉👉 剑指JUC原理-18.同步协作-CSDN博客

线程安全集合

本章节主要介绍了常见的第三代线程安全集合,当然得需要先学会其前置知识HashMap,详细介绍了HashMap在多线程的情况下出现的问题,以及ConcurrentHashMap 在不同的版本做的改进,然后还有阻塞队列 以及 CopyOnWrite思想,当然最本质的还是 一致性 和 并发性的问题,这个最直接的体现就是数据库的MVCC 和 LongAddar。

👉👉👉 如果面试也能这样说HashMap,那么就不会有那么多遗憾!-CSDN博客

👉👉👉 剑指JUC原理-19.线程安全集合-CSDN博客

并发编程实践

相信通过前面铺垫的20章,对于并发编程在原理层次应该是非常熟悉的了,在我的认知里,如果学习了原理性的知识而不去实战,那么这样学习是完全没有意义的,所以为了巩固我之所学,一个集成了网络上众多并发实战应用性的专题应运而生,详细的介绍了并发编程到底可以做什么,到底能够解决那些实际的问题,以及其局限性的思考,这些在我眼里是非常重要的,也就是知行合一的过程!

👉👉👉 剑指JUC原理-20.并发编程实践-CSDN博客

总结

学习JUC是完善整个后端体系必不可少的一环,因为很多Java后端的中间件或者框架其本身内部大量的涉及到了JUC的部分,并且也可以在阅读JUC源码的过程中明白思想,其实思想都是互通的,例如ReentrantLock的原理本质上和Redisson 的原理是类似的,那么就可以迅速过度到分布式锁的使用中。

总的来说,当完整的学习完JUC的部分,也相当于内功更胜一步,这比我当初做完谷粒商城的感觉还好,感觉作为程序员的核心素养更强了,感触良多,耗时一个月,其所体现的绝不是这二十一篇文章这么简单,更多的是传递思想,传递动力,我行你也行的态度!!!

最后分享给大家一句我非常喜欢的话吧。

种一棵树最好的时间是十年前,其次是现在

http://www.niftyadmin.cn/n/5197256.html

相关文章

Zotero在word中插入带超链接的参考文献/交叉引用/跳转参考文献

Zotero以其丰富的插件而闻名&#xff0c;使用起来十分的带劲&#xff0c;最重要的是它是免费的、不卡顿&#xff0c;不像某专业软件。 然而Zotero在word插入参考文献时&#xff0c;无法为参考文献添加超链接&#xff0c;这是一个不得不提的遗憾。 不过&#xff0c;有大佬已经…

bitmap实践-留存计算

目录 1. 介绍2. 留存问题3. 思路解析4. 逻辑4.1 b表建设4.2 留存计算4.3 近X天的访问天数 5.分析 1. 介绍 bitmap方法是数据压缩使用的常用算法&#xff0c;当字段有明确上下界的时候&#xff0c;使用位图模式来减少存储。在业务指标体系中特别适合通用型留存指标的计算。 2.…

热度很高的小米汽车,有两个关键点决定它明年能不能大卖

监制 | 何玺 排版 | 叶媛 小米汽车再传新消息。 据了解&#xff0c;小米汽车已经拿到了工信部的“准生证”&#xff0c;预计将在明年正式发布。 消息传出后&#xff0c;小米新车立刻成为媒体“曝光”的焦点。这款车外形如何、价格什么档次&#xff1f;最关键的是&#xff0c…

JDY蓝牙注意事项

波特率设置&#xff1a;9600&#xff0c;不接受115200&#xff0c;或者38400. 不同于WiFi测试&#xff0c;jdy蓝牙不接受AT"指令&#xff0c;可以使用“ATVERSION"指令测试 安信可公司的那个蓝牙指令在这里没有用&#xff0c;不知道是不是生产的公司不一样

基于java的企业办公自动化系统设计与实现【附源码+lun文】

毕业论文 企业办公自动化系统设计与实现 摘 要 办公自动化&#xff08;Office Automation,简称OA&#xff09;是将现代化办公和计算机网络功能结合起来的一种新型的办公方式。企业办公自动化系统在此基础上实现企业的快速运转和交流&#xff0c;进而有效提高企业办公效率。 本文…

建筑可视化中的 3D 纹理

在线工具推荐&#xff1a; 三维数字孪生场景工具 - GLTF/GLB在线编辑器 - Three.js AI自动纹理化开发 - YOLO 虚幻合成数据生成器 - 3D模型在线转换 - 3D模型预览图生成服务 1、什么是 3D 纹理&#xff1f; 纹理是将二维图像添加到三维模型的技术艺术。虽然对物体进行纹…

ATFX汇市:欧元区10月CPI年率终值不变,EURUSD逼近1.1000心理关口

ATFX汇市&#xff1a;据欧盟统计局11月17日发布的数据&#xff0c;欧元区10月名义CPI年率终值2.9%&#xff0c;与10月末公布的初值持平。欧央行对通胀率的长期调控目标为2%左右&#xff0c;10月份名义CPI年率已经非常接近目标范围&#xff0c;欧央行继续加息的紧迫性降低。10月…

渗透测试面试中常见的问题收集(部分)

1、xss盲打到内网服务器的利用 钓鱼管理员 信息收集 2、什么是虚拟机逃逸&#xff1f; 利用虚拟机软件或者虚拟机中运行的软件的漏洞进行攻击&#xff0c;以达到攻击或控制虚拟机宿主操作系统的目的 3、了解过websocket吗&#xff1f; WebSocket是一种在单个TCP连接上进行…