news 2026/5/9 19:04:33

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
线程是进程内的独立调度单位,是CPU调度的基本单元

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

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

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

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

具体管理方式:

  1. 单一连续区管理:

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

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

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

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

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

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

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

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

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:29:28

早停法(Early_Stopping)

目的:在模型达到最好效果的时候停止训练 设定一个监视值(monitor) 设定监视值不再发生改善前允许训练的最大次数 代码实现: 在model.fit之前添加: early_stop keras.callbacks.EarlyStopping(monitorval_loss, patience10) #模型训练中监视的值为val_loss,当模型在持续训练10个…

作者头像 李华
网站建设 2026/5/9 9:07:10

17、Linux 常用 Shell 命令与快捷方式指南

Linux 常用 Shell 命令与快捷方式指南 1. 用户实用工具 在日常的工作中,我们常常会有修改密码、更换 Shell、查找文件等需求。下面介绍一些实用的命令来满足这些需求。 1.1 修改密码:passwd 使用 passwd 命令可以修改用户密码。该命令是交互式的,会先要求输入当前密码…

作者头像 李华
网站建设 2026/4/30 15:13:45

22、Linux系统:备份、安装与管理全攻略

Linux系统:备份、安装与管理全攻略 在Linux系统的使用过程中,数据备份和软件安装是至关重要的环节。合理的数据备份可以防止数据丢失,而高效的软件安装则能让系统功能不断扩展。下面将详细介绍Linux系统的数据备份和软件安装的相关知识。 数据备份 数据备份是保障数据安全…

作者头像 李华
网站建设 2026/5/8 6:30:36

28、Debian 软件包创建与管理全解析

Debian 软件包创建与管理全解析 1. 本地 APT 仓库 在构建自定义 Debian 软件包时,需要一个 APT 仓库来分发这些软件包。虽然可以手动复制 DEB 文件并使用 dpkg 进行安装,但在涉及多台机器时,这种方法会变得非常繁琐。 设置 APT 仓库是一项简单的任务。无论 APT 的访问方式…

作者头像 李华
网站建设 2026/5/7 5:28:09

43、处理器调度与数据安全隐写技术解析

处理器调度与数据安全隐写技术解析 在计算机系统中,处理器调度和数据安全传输一直是重要的研究领域。下面将详细介绍处理器调度算法以及基于隐写术的数据安全传输方法。 自配置处理器调度窗口算法 在多处理器系统中,为了提高资源利用率,会采用自配置处理器调度窗口算法。…

作者头像 李华