码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【直播笔记0628】 高频面试并发的本质:JAVA程序员应该掌握的并发知识


    这里写自定义目录标题

      • 可见性
      • 有序性
        • 面试题1
        • 面试题:this溢出问题
        • 加问DCL要不要加volatile问题?
          • 为什么要有重排序?
          • 什么情况下能重排?什么情况下不能重排?
          • 如何控制乱序?
    • 屏障

    多线程与高并发

    可见性

    一个程序是怎么跑的?
    内存里,语句构成。被操作系统读进cpu里,去执行。

    cpu比内存快100倍。
    于是存在缓存。

    cpu:寄存器,ALU,
    在这里插入图片描述
    多级缓存的架构?有利有弊
    三级缓存比较合适
    在这里插入图片描述
    找数据,先从L1找,有就返回,没有就L2,L3。 还是没有的话,从内存中读,放在L123中。

    局部性原理
    取大块的数据: 命中率比较高,消耗的资源比较高。
    取小块的数据:低,低
    合适的大小: 8个或64个字节(缓存行)

    在这里插入图片描述
    有6个备份
    左边的改了数据,怎么通知右边的?
    在所有的机器里面必须拥有一种机制来进行数据同步

    所有的硬件都有缓存一致性协议
    英特尔中是 MESI
    还有就是 MOSI

    在这里插入图片描述
    不在一个缓存行,避免了缓存一致性

    在一个缓存行的话,每做一个修改,要通知其他cpu中的缓存修改。

    在这里插入图片描述

    链表头指针,尾指针。

    环形缓存区,只需要一个指针

    在这里插入图片描述
    由于缓存一致性,所以放了7个数据。
    在这里插入图片描述
    他的父类,也就是前面有7个。
    在这里插入图片描述
    不会和其他有用的数据在同一行,避免把时间浪费在缓存一致性上。

    用空间换时间
    在这里插入图片描述

    有序性

    结论:单线程里 ,看到的执行顺序和 实际执行的顺序 有可能不一样。

    在这里插入图片描述

    在这里插入图片描述

    面试题1

    在这里插入图片描述

    在这里插入图片描述
    可能发生乱序,run线程会打印0;

    面试题:this溢出问题

    在这里插入图片描述
    理论上 不一定是8,有可能是0;

    在这里插入图片描述
    汇编码:
    在这里插入图片描述
    1: new 申请一块空间,java默认值是0或者null
    4 : 调用构造方法,才能变为8
    7: 将t指针指向 这块空间

    在这里插入图片描述
    7跑前面去了

    不可以在构造方法里启动线程

    加问DCL要不要加volatile问题?

    DCL:double check lock 双重检测锁
    在这里插入图片描述
    外面的if有没有必要:有,因为没有的话,所有线程都需要锁竞争,效率太低了。

    在这里插入图片描述
    要不要加volatile?

    第一个线程
    在这里插入图片描述
    换了顺序
    在这里插入图片描述
    正好第二个线程来了,判断不等空,就没有
    在这里插入图片描述
    问题: 为什么能访问第一个线程的中间状态?
    是线程2的第一个if的访问,非上锁的代码可以访问上锁的代码的中间态。

    上锁不能保证有序性。

    为什么要有重排序?

    提升效率,
    取数据100ns
    ++操作1ns

    不排序 101ns
    ++前 100ns
    在这里插入图片描述

    什么情况下能重排?什么情况下不能重排?

    程序判断。
    不影响结果一致性就可以换。

    如何控制乱序?

    乱序在单线程里没有问题

    as-if-serial:看上去像序列化
    happens-before原则:jvm级别的保障,八条原则,

    如何不换顺序:通过内存屏障
    屏障指令,前后的语句不会换顺序。

    屏障

    jvm级别的屏障
    在这里插入图片描述
    要不要加volatile?
    就加了屏障,
    所有的写操作前面有SS,后面有SL
    所有的读操作后面有LL和LS。
    在这里插入图片描述

    cpu级别的屏障

    在这里插入图片描述
    https://cloud.fynote.com/share/d/12042

  • 相关阅读:
    初创公司低预算,如何做好品牌宣传?
    大数据讲课笔记1.3 Linux目录操作
    如何去做短视频?
    数据结构题目收录(十九)
    C语言每日一题(6):求五位数中的变种水仙花数
    【web-避开客户端控件】(2.2.1)收集使用数据: 长度限制、资源副本、基于脚本的确认、禁用的元素
    Python和C++音调音符规划和算法
    python如何输出 田字格
    黄金投资新手指南:投资现货黄金怎样开户?
    JAVA:实现UnionFind联合查找算法(附完整源码)
  • 原文地址:https://blog.csdn.net/prague6695/article/details/125509050
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号