【Java 并发编程】线程简介 ( 并发类型 | 线程状态 | CPU 数据缓存 )

举报
韩曙亮 发表于 2022/01/13 01:20:01 2022/01/13
【摘要】 文章目录 一、并发类型二、线程状态三、CPU 数据缓存 一、并发类型 并发类型 : ThreadRunnableFutureThreadPool 其中 Runn...





一、并发类型



并发类型 :

  • Thread
  • Runnable
  • Future
  • ThreadPool

其中 Runnable , ThreadPool 都是基于 Thread 执行的 ;





二、线程状态



线程状态 :

线程刚创建时 , 处于 " 新建状态 " ;

调用线程 start() 方法之后 , 线程进入 Runnable " 可运行状态 " , 此时等待 OS 调度分配 CPU 时间片 运行 ;

线程分配到 CPU 时间片 之后 , 线程进入 Running " 运行状态 " , 如果线程分配的 CPU 时间片运行完毕 , 线程又回到 Runnable " 可运行状态 " ;

如果运行过程中 , 手动调用了 Thread.sleep()join()方法 , 线程进入了 " 阻塞状态 " , 线程唤醒之后又回到 Runnable " 运行状态 " ;

线程运行完毕之后 , 或者线程执行出现异常 , 进入 Dead " 死亡状态 " ;





三、CPU 数据缓存



程序执行时 , 主要是 CPU 执行程序中的指令 , 指令的运行 , 还需要 加载相应的数据 ;

CPU 运行的速度很快 , 如果每次 使用 I/O 总线访问内存获取 CPU 执行所需的数据 , 无法将 CPU 的性能优势发挥到最大 ;


数据从 磁盘 中读取 , 加入到 内存 中 , 线程执行后 , 会将需要操作的数据加入到 CPU 缓存 中 ;

CPU 缓存分为 L1 , L2 , L3 , 3 3 3 个级别的缓存 , 如下图所示 ;

在这里插入图片描述

CPU 执行线程时 , 不直接操作内存中的数据 , 而是通过 CPU 缓存进行处理 ;


JMM ( Java Memory Model - Java 内存模型 ) 参考了 CPU 缓存模型 , CPU 都是多核的 , 每个核中都有 L1 和 L2 缓存 , L3 缓存整个 CPU 的所有核心共同使用 ;

在这里插入图片描述

Java 内存模型只是一种规范 ;

Java 虚拟机运行时内存 , 是不同的虚拟机实现的不同的内存使用方式 ;

每种虚拟机的底层实现都是不同的 ;


Java 线程 运行时 , 每个 Java 线程都配套一个 工作内存 , 然后工作内存从 主内存 中获取数据 , 主内存被所有工作内存共享 ;

  • 工作内存 就是 线程的 本地内存 , 其中存储的是主内存中的 变量副本 , 使用主内存的变量前 , 先将变量拷贝工作内存中 ;
  • 当在线程中 修改了工作内存中的数据 , 需要同时 将变量的修改同步到主内存中 ;

这里的 工作线程 / 本地线程 相当于 CPU 中的 L1 / L2 缓存 , 主内存 相当于 CPU 中的 L3 缓存 ;


如果多个线程同时对 主内存 中的同一个变量进行修改 , 变量的值被不同线程按照不同顺序进行改变 , 主线程中的这个变量是 线程不安全的 ;

文章来源: hanshuliang.blog.csdn.net,作者:韩曙亮,版权归原作者所有,如需转载,请联系作者。

原文链接:hanshuliang.blog.csdn.net/article/details/120166951

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。