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

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

文章目录

一、并发类型

二、线程状态

三、CPU 数据缓存





一、并发类型


并发类型 :


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 33 个级别的缓存 , 如下图所示 ;

image.png



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



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

image.png



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


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


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



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


工作内存 就是 线程的 本地内存 , 其中存储的是主内存中的 变量副本 , 使用主内存的变量前 , 先将变量拷贝工作内存中 ;

当在线程中 修改了工作内存中的数据 , 需要同时 将变量的修改同步到主内存中 ;

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



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


目录
相关文章
|
6月前
|
Java API 开发工具
【Azure Developer】Java代码实现获取Azure 资源的指标数据却报错 "invalid time interval input"
在使用 Java 调用虚拟机 API 获取指标数据时,因本地时区设置非 UTC,导致时间格式解析错误。解决方法是在代码中手动指定时区为 UTC,使用 `ZoneOffset.ofHours(0)` 并结合 `withOffsetSameInstant` 方法进行时区转换,从而避免因时区差异引发的时间格式问题。
312 4
|
7月前
|
数据采集 JSON Java
Java爬虫获取1688店铺所有商品接口数据实战指南
本文介绍如何使用Java爬虫技术高效获取1688店铺商品信息,涵盖环境搭建、API调用、签名生成及数据抓取全流程,并附完整代码示例,助力市场分析与选品决策。
|
7月前
|
数据采集 存储 前端开发
Java爬虫性能优化:多线程抓取JSP动态数据实践
Java爬虫性能优化:多线程抓取JSP动态数据实践
|
8月前
|
Java API 调度
从阻塞到畅通:Java虚拟线程开启并发新纪元
从阻塞到畅通:Java虚拟线程开启并发新纪元
423 83
|
8月前
|
存储 Java 调度
Java虚拟线程:轻量级并发的革命性突破
Java虚拟线程:轻量级并发的革命性突破
462 83
|
5月前
|
设计模式 缓存 安全
【JUC】(6)带你了解共享模型之 享元和不可变 模型并初步带你了解并发工具 线程池Pool,文章内还有饥饿问题、设计模式之工作线程的解决于实现
JUC专栏第六篇,本文带你了解两个共享模型:享元和不可变 模型,并初步带你了解并发工具 线程池Pool,文章中还有解决饥饿问题、设计模式之工作线程的实现
320 2
|
6月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
441 16
|
10月前
|
机器学习/深度学习 消息中间件 存储
【高薪程序员必看】万字长文拆解Java并发编程!(9-2):并发工具-线程池
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中的强力并发工具-线程池,废话不多说让我们直接开始。
380 0
|
安全 Java 调度
解锁Java并发编程高阶技能:深入剖析无锁CAS机制、揭秘魔法类Unsafe、精通原子包Atomic,打造高效并发应用
【8月更文挑战第4天】在Java并发编程中,无锁编程以高性能和低延迟应对高并发挑战。核心在于无锁CAS(Compare-And-Swap)机制,它基于硬件支持,确保原子性更新;Unsafe类提供底层内存操作,实现CAS;原子包java.util.concurrent.atomic封装了CAS操作,简化并发编程。通过`AtomicInteger`示例,展现了线程安全的自增操作,突显了这些技术在构建高效并发程序中的关键作用。
249 1

热门文章

最新文章