Java基础夯实——2.7 线程上下文切换

news2024/11/23 11:47:19

线程上下文切换(Thread Context Switching)是操作系统在多线程环境中,切换CPU从执行一个线程的上下文到另一个线程的上下文的过程。这种切换是实现多线程并发执行的核心机制之一。

1 上下文:

线程的上下文指线程在某一时刻的执行状态,如:

  1. CPU寄存器状态:线程当前的指令地址(程序计数器)以及其他寄存器的值。
  2. 栈信息:线程的调用栈,包含函数调用信息和局部变量。
  3. 线程本地存储:线程相关的局部变量和特定资源。
  4. 线程控制块(TCB):操作系统维护的线程管理数据结构,记录线程的优先级、状态等。

2 上下文切换过程

保存当前线程的上下文
操作系统暂停当前线程的执行,并保存其上下文信息到线程控制块(Thread Control Block, TCB)中。

选择下一个要运行的线程
操作系统的调度器根据调度策略(如优先级、时间片轮转等)从就绪队列中选出一个可以运行的线程。

加载目标线程的上下文
调度器将选中的目标线程的上下文从其线程控制块(TCB)中恢复到CPU中。恢复的内容包括:

  • 恢复程序计数器,使CPU能够继续执行目标线程的下一条指令。
  • 恢复寄存器的状态,确保目标线程的执行环境与切换前一致。
  • 恢复堆栈指针和线程本地存储,保证调用栈和局部变量的正确性。

更新线程状态

  • 将目标线程的状态从“就绪”更新为“运行”。
  • 将前一个线程的状态更新为“阻塞”或“就绪”(取决于切换原因)。

恢复执行目标线程
目标线程的上下文完全加载到CPU后,操作系统将控制权交还给CPU,继续执行目标线程的下一条指令。这一过程对程序透明,线程不会感知到发生了上下文切换。

3 线程上下文切换的关键点

  • 中断机制:大多数上下文切换通过中断触发,确保系统能够在适当时机检查需要切换的条件。
  • 线程控制块(TCB):保存和管理线程上下文的核心数据结构。
  • 调度器决策:根据调度算法选择下一线程,平衡系统性能和资源利用率。

4 上下文切换的触发条件

线程上下文切换通常发生在以下情况:

  1. 时间片耗尽:在时间片轮转调度中,当前线程运行时间用尽,操作系统切换到下一个线程。
  2. 线程阻塞:线程因I/O操作或资源不可用进入阻塞状态,操作系统调度其他线程执行。
  3. 高优先级线程就绪:更高优先级的线程准备好运行时,操作系统可能抢占当前线程。
  4. 用户主动切换:通过API(如yield)让出CPU使用权。

5 上下文切换的开销

线程上下文切换会引入一定的性能开销,包括:

  1. CPU开销:保存和恢复寄存器状态以及其他上下文信息。
  2. 缓存污染:切换线程可能导致CPU缓存失效(Cache Miss),因为新线程的数据未必在缓存中。
  3. 操作系统调度延迟:调度器需要决定下一个运行的线程,这也会耗费时间。

6 减少上下文切换的方法

  1. 使用协程:协程切换在用户态完成,开销比线程切换小。
  2. 优化线程数:根据实际工作负载合理分配线程,避免过多线程导致频繁切换。
  3. 提高代码效率:减少线程阻塞的可能性,尽量让线程在可运行状态下持续工作。

7 相关问题

1. 什么是线程上下文切换?

线程上下文切换是指操作系统将CPU的执行权从一个线程切换到另一个线程的过程,用于实现并发执行。

核心概念:

  • 线程上下文:指线程的执行状态,包括:
    • 程序计数器(PC):记录线程正在执行的指令位置。
    • CPU寄存器内容:保存线程正在处理的数据和指令信息。
    • 栈指针(SP):指向线程的调用栈,用于管理函数调用和局部变量。
    • 线程控制块(TCB):记录线程的元信息,如优先级、状态等。

切换过程:

  • 保存当前线程状态:暂停线程运行,将其上下文保存到内存。
  • 加载目标线程状态:从目标线程的线程控制块中恢复其上下文,准备继续执行。

触发条件:

  • 时间片耗尽。
  • 当前线程阻塞(如等待I/O)。
  • 高优先级线程需要运行。
  • 用户主动调用切换API。

2. CPU时间片轮询机制

CPU时间片轮询机制(Time-Slice Round Robin)是一种操作系统调度策略,用于在多个线程或进程之间公平分配CPU资源。

  • 时间片(Time Slice):操作系统为每个线程分配的一段CPU执行时间。
  • 轮询机制(Round Robin):线程按照固定顺序排队,依次获得CPU时间片。

工作原理:

  1. 调度器将线程放入就绪队列。
  2. CPU运行队列中的第一个线程,并计时。
  3. 时间片耗尽:
    • 如果线程未完成任务,则保存其上下文,并将其放回队列末尾。
    • 如果线程完成任务,则从队列中移除。
  4. 调度器运行队列中的下一个线程。

适用场景:

  • 适用于对交互响应要求较高的系统,如桌面操作系统。
  • 不适合对实时性要求严格的系统。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2245974.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

五天SpringCloud计划——DAY2之单体架构和微服务架构的选择和转换原则

一、引言 选择合适的架构模式是一个至关重要的决策,尤其是在单体架构和微服务架构之间的选择,本文将带大家认识什么是单体架构,什么是微服务架构,以及两者如何去选择,如何去转换。 二、什么是单体架构 单体架构&a…

【网络协议】【TCP】精讲TCP数据包传递的地址解析(含三次握手四次挥手图文并茂精华版)

目录 前言 1.TCP定义 1.1 什么是面向连接? 1.2 什么是可靠的通信协议? 1.3 什么是面向字节流的? 2. 数据包传递的地址解析 3. 三次握手过程详解 3.1 第一次握手 3.2 第二次握手 3.3 第三次握手 4. 四次挥手 4.1 第一次挥手 4.2 第二次挥手 4.3 第三次挥手 4.…

Win11 24H2新BUG或影响30%CPU性能,修复方法在这里

原文转载修改自(更多互联网新闻/搞机小知识): 一招提升Win11 24H2 CPU 30%性能,小BUG大影响 就在刚刚,小江在网上冲浪的时候突然发现了这么一则帖子,标题如下:基准测试(特别是 Time…

人工智能的核心思想-神经网络

神经网络原理 引言 在理解ChatGPT之前,我们需要从神经网络开始,了解最简单的“鹦鹉学舌”是如何实现的。神经网络是人工智能领域的基础,它模仿了人脑神经元的结构和功能,通过学习和训练来解决复杂的任务。本文将详细介绍神经网络…

socket连接封装

效果: class websocketMessage {constructor(params) {this.params params; // 传入的参数this.socket null;this.lockReconnect false; // 重连的锁this.socketTimer null; // 心跳this.lockTimer null; // 重连this.timeout 3000; // 发送消息this.callbac…

蓝桥杯每日真题 - 第17天

题目:(最大数字) 题目描述(13届 C&C B组D题) 题目分析: 操作规则: 1号操作:将数字加1(如果该数字为9,变为0)。 2号操作:将数字…

探索免费的Figma中文版:开启高效设计之旅

在当今数字化设计的浪潮中,Figma以其强大的云端协作功能和出色的设计能力,成为了众多设计师的心头好。而对于国内的设计师来说,能够免费使用Figma中文版更是一大福音,下面就来一起探索一下吧。 一、Figma中文版的获取途径 虽然F…

leetcode:112. 路径总和

给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和 targetSum 。如果存在,返回 true ;否则,返回 false 。 叶子节点 是指没有子节点…

新160个crackme - 100-E-crackme

运行分析 需根据机器码,填写正确注册码 PE分析 C程序,32位,无壳 静态分析&动态调试 ida无法搜到字符串,使用暂停法找关键函数 首先启动ida动态调试,点击注册来到错误弹窗 点击Debugger -> Pause process 发现断…

VSCode 间距太小

setting->font family 使用:Consolas, Courier New, monospace 字体

七、电机三环控制

电机三环控制指的是,直流有刷电机三环(电流环速度环位置环)PID 控制。 1、三环PID控制原理 三环 PID 控制就是将三个 PID 控制系统(例如:电流环、速度环以及位置环)串联起来,然后对前一个系统…

【快讯】亚马逊(AMZN.US)关联方拟出售7.08万股股份,价值约1,407.69万美元

根据美国证券交易委员会(SEC)美东时间11月21日披露的文件,亚马逊(AMZN.US)关联方BEZOS EARTH FUND FOUNDATION拟于11月21日出售7.08万股普通股股份,总市值约1,407.69万美元。此外,BEZOS EARTH FUND FOUNDATION自2024年…

影响电阻可靠性的因素

一、影响电阻可靠性的因素: 影响电阻可靠性的因素有温度系数、额定功率,最大工作电压、固有噪声和电压系数 (一)温度系数 电阻的温度系数表示当温度改变1摄氏度时,电阻阻值的相对变化,单位为ppm/C.电阻温度…

51c大模型~合集76

我自己的原文哦~ https://blog.51cto.com/whaosoft/12617524 #诺奖得主哈萨比斯新作登Nature,AlphaQubit解码出更可靠量子计算机 谷歌「Alpha」家族又壮大了,这次瞄准了量子计算领域。 今天凌晨,新晋诺贝尔化学奖得主、DeepMind 创始人哈萨…

深入了解 Linux htop 命令:功能、用法与示例

文章目录 深入了解 Linux htop 命令:功能、用法与示例什么是 htop?htop 的安装htop的基本功能A区:系统资源使用情况B区:系统概览信息C区:进程列表D区:功能键快捷方式 与 top 的对比常见用法与示例实际场景应…

XML文件(超详细):XML文件概念、作用、写法、如何用程序解析XML、写入XML、dom4j框架、DTD文档、schema文档

目录 1、什么是XML文件?和properties属性文件有什么区别?和txt文本文件有什么区别? 2、XML文件的用途 3、XML的格式 4、如何解析XML文件 5、如何写入XML文件 6、约束XML的书写格式 6.1 DTD文档-约束书写格式,但是不能约束具…

通过端口测试验证网络安全策略

基于网络安全需求,项目中的主机间可能会有不同的网络安全策略,这当然是好的,但很多时候,在解决网络安全问题的时候,同时引入了新的问题,如k8s集群必须在主机间开放udp端口,否则集群不能正常的运…

国产光耦合器的竞争优势与市场发展前景

国产光耦合器近年来在技术研发和市场表现上取得了显著进步,逐渐在国际市场中占据了一席之地。作为实现电气隔离和信号传输的核心器件,光耦合器在工业控制、通信设备、消费电子等领域中有着广泛的应用。国产光耦合器凭借其独特的成本、技术和市场优势&…

Wi-Fi 8标准已经发布,准备好了吗

今年初,Wi-Fi联盟宣布完成并推出了Wi-Fi 7高级无线标准的认证,将改善家庭、办公室和工业用途设备的连接性能,同时还带来了新的认证标志。其在Wi-Fi 6E的基础上引入了320MHz信道带宽、4096-QAM调制、Multi-RU、多链路操作、增强MU-MIMO、多AP协…

STM32F407ZGT6驱动TCA9535扩展16路IO

目录 一、TCA9535 I/O 扩展器1、TCA9535 的 I2C 地址2、TCA9535 的读写操作3、TCA9535 的控制寄存器4、输入寄存器 0/15、输出寄存器 0/16、极性反转寄存器 0/17、配置寄存器 0/1 二、硬件设计1、接线说明2、硬件参考 三、程序设计1、tca9535_softiic.c2、tca9535_softiic.h3、…