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

操作系统-用户级-内核级线程

一、先明确几个基本概念:

  1. 用户级线程(ULT)

    • 完全由用户空间的线程库(如 pthreadgreen threads)管理。

    • 操作系统内核对此一无所知。

    • 切换线程时,不需要进入内核,效率高,但缺乏内核调度的支持。

  2. 内核级线程(KLT)

    • 每个线程都由操作系统内核管理,调度和切换由内核负责。

    • 可以在多核CPU上并行执行

  3. 进程和线程的关系

    • 一个进程可以包含多个线程。

    • 多线程程序是否能在多核CPU上并发执行,取决于线程的实现方式。

🔹二、为什么用户级线程不能利用多核?

🌟根本原因:内核只看到一个“线程”

当使用用户级线程时:

  • 在内核看来,整个进程就只有一个执行实体(即一个内核线程/调度单位)。

  • 所以不管你在用户空间创建了多少“线程”,内核都只能把这个进程调度到一个CPU上执行。

  • 这就意味着,即使有多个CPU核心,也只能在一个核心上跑一个用户线程其他线程只能排队等候

🔹三、为什么不能多个用户线程同时执行?

因为:

  • 用户级线程的调度完全在用户空间,不需要内核介入;

  • 但进程只有一个内核线程被调度,CPU只允许这个“唯一的”线程执行代码

  • 所以其他用户线程只能等待,不可能同时运行,更不能跨多个核心运行。

🔹总结一句话:

用户级线程不能利用多CPU,是因为内核只为整个进程分配一个执行实体(一个内核线程),因此同一时刻只能有一个用户线程运行。

✅一个线程 运行时 需要占用一个 CPU

http://www.xdnf.cn/news/1051.html

相关文章:

  • 西门子地址表规划中,如WM200与WM201这样相邻地址冲突问题
  • 工厂模式:工厂方法模式 和 抽象工厂模式
  • VulnHub-DarkHole_1靶机渗透教程
  • Linux驱动模块双机调试详细步骤
  • Linux学习——UDP
  • PowerQuery逆透视将二维表转换为一维表
  • 【家政平台开发(67)】家政平台移动端性能优化:打造极致用户体验
  • Spring集合注入Bean
  • Oracle数据库学习之路-目录
  • PyTorch与自然语言处理:从零构建基于LSTM的词性标注器
  • Docker离线安装与配置指南
  • 安装 Conda 环境
  • Linux 一些常用的命令记录
  • pdf多文件合并
  • Elasticsearch性能优化实践
  • SQL简介
  • SystemV-消息队列与责任链模式
  • 神经网络的 “成长密码”:正向传播与反向传播深度解析(四)
  • 联邦元学习实现个性化物联网的框架
  • 【开关电源】关于GaN反激电源开关噪声
  • 微信小程序拖拽排序有效果图
  • C++学习之类与对象
  • Redis的数据持久化是怎么做的?
  • 【无人机】问题分析。查看电机转速时,四个电机转速不一致,QGC中检测到电机转速不均衡
  • webpack详细打包配置,包含性能优化、资源处理...
  • 简述大疆无人机对接
  • Python爬虫从入门到实战详细版教程
  • 【AI提示词】投资策略专家
  • 蓝耘平台介绍:算力赋能AI创新的智算云平台
  • Android RecyclerView 多布局场景下的设计思考:SRP 与 OCP 的权衡与优化