当前位置: 首页 > news >正文

线程是进程内的独立调度单位,是CPU调度的基本单元

一、线程(进程管理部分)
定义:线程是进程内的独立调度单位,是CPU调度的基本单元。它只拥有运行所必需的少量资源(如程序计数器、寄存器、栈等),而与同属一个进程的其他线程共享该进程的代码段、数据段、打开的文件和系统资源。
特点:

  • 可并发执行,提高程序响应性和资源利用率;
  • 线程切换开销小,因为不需要切换地址空间和内存映射,仅需保存/恢复寄存器状态和栈信息;
  • 同一进程内的线程共享全局变量和堆空间,通信和数据共享更高效,但需要同步机制避免竞争条件。

二、存储管理
核心对象:内存,尤其是主存(RAM),是操作系统必须高效管理的核心资源之一。
管理目标:

  • 提高内存利用率;
  • 实现内存的动态分配与回收;
  • 提供内存保护机制防止非法访问;
  • 通过虚拟内存技术实现内存扩充,支持多道程序并发运行。

具体管理方式:

  1. 单一连续区管理:

    • 应用于早期单道批处理系统;
    • 整个用户内存空间被一个作业独占;
    • 静态分配,作业运行前一次性装入;
    • 无内存保护机制,程序错误可能破坏操作系统区域,导致系统崩溃;
    • 结构简单但资源利用率低。
  2. 分区存储管理:

    • 核心思想:将内存划分为若干个连续的分区,每个分区容纳一个作业;
    • 要求作业在加载时必须一次性全部装入且地址连续;
    • 分为两种类型:
      a) 固定分区(静态分区):
      • 内存在系统启动时就被划分为若干大小不等或相等的固定分区;
      • 每个分区只能装一个作业,即使作业较小也会浪费剩余空间(内部碎片);
      • 使用分区表记录各分区的起始地址、大小、使用状态等信息;
      • 管理简单,但缺乏灵活性,内存利用率不高。
        b) 动态分区:
      • 分区不是预先固定的,而是根据作业需求动态创建;
      • 初始时整个用户内存为空闲区,随着作业进入进行分割;
      • 存在外部碎片问题,可通过“紧凑”(compaction)技术缓解;
      • 常用分配算法包括首次适应、最佳适应、最坏适应等。
        线程与进程的主要区别如下:
对比维度进程(Process)线程(Thread)
定义操作系统资源分配的基本单位,是程序的一次执行过程进程内的执行单元,是CPU调度的基本单位
资源拥有拥有独立的地址空间、文件描述符、信号处理、环境变量等系统资源不拥有系统资源,仅拥有运行所需的栈、寄存器、程序计数器等少量资源
地址空间每个进程有自己独立的虚拟地址空间,相互隔离同一进程内的线程共享该进程的地址空间和全局数据
通信方式进程间通信(IPC)复杂,需借助管道、消息队列、共享内存等机制线程间可直接通过共享变量通信,更高效但需同步控制
创建/销毁开销较大,涉及内存映射、资源分配等操作小,无需创建新地址空间,只需分配栈和线程控制块
切换开销高,需保存和恢复整个地址空间、页表、寄存器等低,仅需保存/恢复寄存器状态和栈信息,无需切换地址空间
独立性进程之间相互独立,一个崩溃不影响其他进程同一进程内某一线程崩溃可能导致整个进程终止
安全性高,地址空间隔离提供天然保护相对较低,共享数据易受竞争条件影响

为什么线程切换比进程切换更快?

线程切换快的主要原因在于资源共享程度高

  1. 无需切换地址空间
    同一进程内的线程共享虚拟地址空间和页表,因此在切换时不需要刷新TLB(转换检测缓冲区)或切换页表基址寄存器(如CR3),避免了昂贵的内存管理单元(MMU)操作。

  2. 上下文更小
    线程切换只需保存和恢复少量寄存器内容(如程序计数器、栈指针、通用寄存器)以及线程栈的信息;而进程切换还需保存整个用户/内核态上下文、内存映射、打开文件列表等。

  3. 无需资源重新分配
    线程共享进程的文件、信号、信号量等资源,切换时不涉及资源归属变更。

  4. 缓存友好性更高
    由于共享内存空间,线程切换后仍能有效利用CPU缓存中的数据,减少缓存未命中。

综上,线程切换本质上是“轻量级”任务切换,适用于需要高并发、快速响应的应用场景(如服务器、GUI程序等)。

http://www.jsqmd.com/news/88207/

相关文章:

  • 20、Debian系统管理:备份与设备管理全解析
  • 终于有人把大模型讲明白了:LLM 从入门到精通全解析
  • 2025年行业内评价好的3A信用认证代办多少钱,3A信用认证/3A企业信用认证/企业信用等级认证3A信用认证代理怎么选择 - 品牌推荐师
  • **P(Bufferfull)**:表示执行 wait 操作(即信号量减 1),用于判断是否有产品可消费
  • 21、Linux 备份指南:保障数据安全的实用方法
  • QMS软件系统:质量成本直降40%,让质管变“智造“——全星质量管理QMS软件系统应用解析
  • 永生数字系统:与之配套的测试哲学
  • 自动化?先搞懂这几点
  • asgiref终极指南:高效解决Python异步通信难题
  • 16、Debian内核:管理、特性与定制全解析
  • 早停法(Early_Stopping)
  • 探索四种商品售货机:MCGS 7.7 与三菱 PLC 联机之旅
  • 突破性多模态架构革命:Qwen3-VL-235B-A22B-Instruct-FP8重塑视觉语言交互边界
  • 医学影像深度学习知识点总结
  • 如何快速定位某个域名(如 deepskai.cn)对应的部署配置与代码目录(CentOS 示例)
  • CentOS 8 中可以使用 **dnf**(yum 的继任者)来安装 Docker。
  • 如何通过AutoGPT生成高质量技术博客为GPU算力引流
  • 18、Linux 远程操作与文件搜索实用技巧
  • Refine Next.js Turbopack 兼容性实战手记:从构建冲突到性能优化的完整指南
  • LIO-SAM性能实战评测:多传感器方案对比与场景适配深度解析
  • PAT 1175 Professional Ability Test
  • 22、Linux系统:备份、安装与管理全攻略
  • 缓存高可用架构-写缓存 - 实践
  • 多目标蜣螂优化算法NSDBO:微电网多目标优化调度的利器
  • 经典Agent架构实战之工具使用 (Tool Use)
  • 2025年市场上有实力的下水道疏通公司推荐,评价高的下水道疏通哪家强永邦环卫显著提升服务 - 品牌推荐师
  • 字符串移位包含问题与删除单词后缀问题
  • 本研究基于分形纤维丛统一场论,构建了黑洞时空的几何模型,揭示了奇点消解、霍金辐射修正及信息守恒的新机制。该模型的优势在于将宏观时空的广义相对论效应与微观量子的分形特性实现了有机融合。
  • 【JavaWeb】HttpServletRequest_获取请求行和请求头
  • [Web自动化] HTML表格标签