博客
关于我
一文看懂进程线程调度
阅读量:235 次
发布时间:2019-03-01

本文共 1075 字,大约阅读时间需要 3 分钟。

进程线程调度是操作系统的核心问题之一,理解它的本质对于掌握操作系统的运行机制至关重要。本文将从线程的创建、运行到调度,逐步揭示进程线程调度的内在逻辑。

一、线程的本质

线程是操作系统调度的基本单位,创造线程的函数原型如下:

int thread(int* thread, char* attr, void* (*start_routine)(void*), void* arg);

线程的核心由四个参数决定,但关键在于函数和它的参数。线程可被调度,独占CPU执行,具备特殊的结构如PCB、栈等。

PCB(Process Control Block)

PCB是进程/线程运行所需的核心信息,包括:

  • 标识符:区分进程的唯一标记。
  • 状态:描述进程/线程的执行状态。
  • 优先级:决定调度顺序。
  • 程序计数器:指向下一条指令地址。
  • 上下文数据:处理器寄存器的状态。
  • I/O状态:记录I/O设备和文件。
  • 记账信息:处理器时间的统计。

在Linux中,task_struct结构体承担PCB的功能,线程与进程无异,线程可视为轻量级进程。

栈的定义

线程的栈用于存储上下文信息,第一次运行时,栈结构如下:

  • 中断栈帧:保存调度时的上下文。
  • 参数地址:传递给线程函数的参数。
  • 调度上下文:线程运行时的寄存器状态。

线程函数的调用遵循cdecl规范,栈帧结构确保正确的函数调用和返回。

二、线程运行与调度

线程运行涉及调度,调度程序schedule()执行两步:

  • 选线程:根据调度策略(如带优先级的时间片轮转)。
  • 切换线程:通过汇编指令保存上下文,切换寄存器和栈顶值。
  • 调度策略

    调度策略决定线程的执行顺序。常用策略包括:

    • 时间片轮转:线程按时间分配 CPU。
    • 优先级调度:优先级高的线程先执行。

    三、进程与线程的区别

    进程是资源分配的基本单位,拥有独立的虚拟地址空间和特权级。线程运行在进程之上,共享资源如寄存器和栈空间。

    进程的特点

    • 独立地址空间:包含代码段、数据段、堆栈等。
    • 特权级3:运行在用户态,需内核态支持创建和调度。
    • 线程支持:进程可包含多个线程,线程调度实体为进程。

    四、设计总结

    线程调度的核心在于栈的使用和上下文切换,进程则基于线程实现,拥有独立地址空间和特权级。理解线程调度需掌握栈结构和调度机制,进程的扩展基于这些基础。

    常见问题解答

    • 资源分配与调度单位:进程是资源分配单位,线程是调度单位。
    • 线程提速原理:线程提供并行执行,提升效率,多线程进程在多任务环境下表现更优。

    通过对线程调度和进程机制的理解,可以更好地掌握操作系统的内核机制,优化程序性能。

    转载地址:http://gpiv.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>