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

2.1_6 线程的实现方式和多线程模型

文章目录

  • 2.1_6 线程的实现方式和多线程模型
    • (一)线程的实现方式
      • (1)用户级线程
      • (2)内核级线程
    • (二)多线程模型
      • (1)一对一模型
      • (2)多对一模型
      • (3)多对多模型
  • 总结

2.1_6 线程的实现方式和多线程模型

image-20240228153544303

(一)线程的实现方式

(1)用户级线程

  用户级线程(User-Level Thread,ULT)。

  历史背景:早期的操作系统(如:早期Unix)只支持进程,不支持线程。当时的“线程”是由线程库实现的。

  以进程的方式实现逻辑上的线程,线程其实就是进程中的一段代码逻辑。很多编程语言提供了强大的线程库,可以实现线程的创建、销毁、调度等功能。

image-20240228154226708

问题

  1.线程的管理工作由谁来完成?

  由于线程只是逻辑上的,实际上还是进程。因此“线程”的管理工作不是由操作系统完成的。是由线程库完成的。

  2.线程切换是否需要CPU变态?(用户态、内核态的转换)

  “线程”只是进程程序中的一段逻辑代码来实现的“逻辑上的线程”,“线程的切换”只是应用程序执行代码逻辑的一个过程(如下图所示),只是在用户态下就能进行进程的切换工作,并不需要操作系统的干涉。

image-20240228154757552

  3.操作系统是否能意识到用户级线程的存在?

  显然,操作系统只能意识到有这个进程的存在。而在这个进程内部,你的代码是如何通过逻辑代码实现“线程”的,操作系统是意识不到这些“线程”的存在的。

  这也是为什么它叫“用户级线程”,就是因为这种线程是只有用户能感受的到,而操作系统感知不到这种线程的存在。

优缺点

  优点:

  用户级线程的切换在用户空间即可完成,不需要切换到核心态,线程管理的系统开销小,效率高。

  缺点:

  1.当一个用户级线程被阻塞后,整个进程都会被阻塞,并发度不高。

  如下图,如果{处理视频聊天的代码;}被阻塞,那么后续的其他“用户级线程”都将得不到执行。

image-20240228155333881

  2.多个线程不可在多核处理机上并行运行。

  它只是逻辑上的线程,实际上还只是进程机制,因此CPU调度的基本单位仍然是进程。

(2)内核级线程

  内核级线程(Kernel-Level Thread,KLT),又称“内核支持的线程”。是从操作系统视角也可以感知到的线程。

  大多数现代操作系统都实现了内核级线程,如Windows、Linux。

  随着操作系统的发展,由操作系统支持的线程,就叫内核级线程。

image-20240228155812412

问题

  1.线程的管理工作由谁来完成?

  当然是由操作系统内核来完成。

  2.线程切换是否需要CPU变态?

  既然这些内核级线程是由操作系统管理的,那么它们之间的切换肯定是要由操作系统介入的。因此,在进行线程切换的时候,当然要由用户态转为内核态,在内核态下才能完成内核级线程的转换。

  3.操作系统是否能意识到内核级线程的存在?

  能。

优缺点

  优点:

  当一个线程被阻塞后,别的线程还可以继续执行,并发能力强。多线程可在多核处理机上并行执行。

  缺点:

  一个用户进程会占用多个内核级线程,线程切换由操作系统内核完成,需要切换到核心态,因此线程管理的成本高,开销大。

(二)多线程模型

  既然“用户级线程”和“内核级线程”都各有优缺点,那么我们不妨将二者结合起来,吸收两者各自的优点。

  例如,可以在内核级线程的机制下,仍然引入线程库,从而使得多个用户级线程映射到一个内核级线程上。

  而映射的方式也不只此一种。根据映射关系不同,可以分为几种模型。

  在支持内核级线程的系统中,根据用户级线程和内核级线程的映射关系,可以划分为几种多线程模型。

(1)一对一模型

  一个用户级线程映射到一个内核级线程。每个用户进程有与用户级线程同数量的内核级线程。

image-20240228160857995

  优点:当一个线程被阻塞后,别的线程还可以继续执行,并发能力强。多线程可在多核处理机上并行执行。(因为线程是处理机分配的最小单位)

  缺点:一个用户进程会占用多个内核级线程,线程切换由操作系统内核完成,需要切换到核心态,因此线程管理的成本高,开销大。(只要涉及CPU频繁变态,开销就比较大)

(2)多对一模型

  多个用户级线程映射到一个内核级线程。且一个进程只被分配一个内核级线程。

image-20240228162035624

  如果是这种模型,其实就已经退化到纯粹的“用户级线程”那种实现模式了。

  优点:用户级线程的切换在用户空间即可完成,不需要切换到核心态,线程管理的系统开销小,效率高。

  缺点:当一个用户级线程被阻塞后,整个进程都会被阻塞,并发度不高。多个线程不可在多核处理机上并行运行。

注意

  既然有“内核级线程”的存在,那么在这种模式下,处理机分配的最小单位就是“内核级线程”。同时,操作系统的视角也只能感知到“内核级线程”。对于“用户级线程”,并不是处理机分配的单位,操作系统也感知不到。

(3)多对多模型

  n个用户级线程映射到m个内核级线程( n ≥ m n≥m nm)。

  每个用户进程对应m个内核级线程。

image-20240228162642427

  它克服了多对一模型并发度不高的缺点(一个阻塞,全体阻塞)。

  它又克服了一对一模型中一个用户进程占用太多内核级进程,开销太大的缺点。

可以这样理解:

  用户级线程是“代码逻辑”的载体。

  内核级线程是“运行机会”的载体。

  内核级线程才是处理机分配的单位。例如:多核CPU环境下,上图这个进程最多能被分配两个核。

  一段“代码逻辑”只有获得了“运行机会”,才能被CPU执行。

  内核级线程中可以运行任意一个有映射关系的用户级线程代码,只有两个内核级线程中正在运行的代码逻辑都阻塞时,这个进程才会阻塞。

  这可以让我们的线程管理有更多的灵活性,例如上图中,如果某一时间段,“视频聊天”需要耗费比较多的系统资源的话,那么我们可以让左边那个内核级线程专门来执行“视频聊天”的功能,而右边那个内核级线程可以让它并发执行“文字聊天”、“文件传输”的功能。如果过了一会儿,“文件传输”需要耗费较多系统资源,则同理。

总结

image-20240228163520455

相关文章:

2.1_6 线程的实现方式和多线程模型

文章目录 2.1_6 线程的实现方式和多线程模型(一)线程的实现方式(1)用户级线程(2)内核级线程 (二)多线程模型(1)一对一模型(2)多对一模…...

4.5 MongoDB 文档存储

目录 1. 相关安装 2. Pycharm可视化观察MongoDB 3. python使用 MongoDB 最初流程代码 4. 插入、查询、更新、删除数据 4.1 插入数据 4.2 查询数据 4.3 更新数据 4.3.1 更新一条数据 4.3.2 更新多条数据 4.4 删除数据 5. 计数、排序、偏移 5.1 计数 5.2 排序 5.3 …...

什么是服务级别协议(SLA)?

在数字化时代,企业和服务提供商之间的关系变得越来越复杂,而服务级别协议(SLA)则在这个复杂网络中发挥着至关重要的作用。本文将深入介绍SLA,从它的定义、应用场景到监测方法,全方位解析这一法律桥梁如何确…...

使用Python进行Sentinel-2 图像聚类

聚类或无监督分类是根据统计相似性将图像的像素值分组或聚合到一定数量的自然类(组)的过程。在本教程中,我们将使用rasterio进行sentinel-2图像处理,并使用功能强大的完整scikit-learn python 包在jupyter Notebook中进行聚类。 Scikit-learn是一个用于 Python 编程语言的…...

SNZ资本的首席信息官Gavin确认出席Hack .Summit() 2024香港开发者大会!

SNZ资本的首席信息官Gavin确认将出席由 Hack VC 主办,并由 AltLayer 和 Berachain 联合主办,与 SNZ 和数码港合作,由 Techub News 承办的Hack.Summit() 2024区块链开发者盛会。 Gavin是SNZ控股和SNZ资本的首席信息官。Gavin在区块链和金融科技…...

js里面有引用传递吗?

一:什么是引用传递 引用传递是相对于值传递的。那什么是值传递呢?值传递就是在传递过程中再复制一份,然后再赋值给变量,例如: let a 2; let b a;在这个代码中,let b a; 就是一个值传递,首先…...

C 语言 math.h 库介绍

在 C 语言中,math.h 头文件定义了各种数学函数和一个宏,用于处理数学运算。这些函数接受 double 类型的参数,并返回 double 类型的结果。 库宏 在 math.h 中定义了唯一的一个宏: HUGE_VAL:当函数的结果不可表示为浮…...

Eigen-Matrix矩阵

Eigen-Matrix矩阵 一、概述二、矩阵的前三个模板参数三、向量四、动态维度参数五、构造函数六、索引访问器七、逗号初始化八、矩阵维度调整九、赋值和调整大小十、固定尺寸vs.动态尺寸十一、可选模板参数十二、方便预定义 一、概述 在Eigen中,所有矩阵和向量都是矩…...

蓝桥杯14届计算思维国赛U8组包含真题和答案

十四届蓝桥杯国赛考试计算思维 U8 组 答案在底部 第一题 以下选项中,( )是由美国计算机协会设立,对在计算机领域内作出重要贡献的个人授予的奖项 。A.图灵奖 C.菲尔兹奖 B.诺贝尔奖 D.普利策奖 第二题 希希去吃寿司。餐台上摆出了许多食物,可供大家自选。如下图所示。 …...

opencv内存溢出del释放变量 (python)

报错: cv2.error: OpenCV(3.4.17) D:\a\opencv-python\opencv-python\opencv\modules\core\src\alloc.cpp:73: error: (-4:Insufficient memory) Failed to allocate 12211548 bytes in function ‘cv::OutOfMemoryError’ 检查内存代码 import psutil# 获取当前进…...

【算法与数据结构】复杂度深度解析(超详解)

文章目录 📝算法效率🌠 算法的复杂度🌠 时间复杂度的概念🌉大O的渐进表示法。 🌠常见复杂度🌠常见时间复杂度计算举例🌉常数阶O(1)🌉对数阶 O(logN)🌉线性阶 O(N)&#x…...

Upload-Labs-Linux1【CTF】

拿到这道题目一看&#xff0c;发现是upload靶场&#xff1b;这不简简单单吗&#xff1b;结果中间还是遇到了一些小问题 小坑总结&#xff1a;该关只识别标准php语法&#xff1a;<?php phpinfo()?>格式&#xff1b;即<?php ?> 不识别<? phpinfo()?> &…...

搜维尔科技:OptiTrack 提供了性能最佳的动作捕捉平台

OptiTrack 动画 我们的 Prime 系列相机和 Motive 软件相结合&#xff0c;产生了世界上最大的捕获量、最精确的 3D 数据和有史以来最高的相机数量。OptiTrack 提供了性能最佳的动作捕捉平台&#xff0c;具有易于使用的制作工作流程以及运行世界上最大舞台所需的深度。 无与伦比…...

java设计模式之职责链模式

基本介绍 职责链模式&#xff08;Chain of Responsibility Pattern&#xff09;为请求创建了一个接收者对象的链。这种模式对请求的发送者和接收者进行解耦。职责链模式 又叫责任链模式&#xff0c;通常每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求。那…...

连不上网的解决办法集--持续更新

连不上网的解决办法集–持续更新 1、有网卡&#xff0c;但网卡驱动失效 背景&#xff1a;有网络驱动但是依旧连不上网&#xff0c;只有inteV6有值&#xff0c;inte 没有值&#xff08;正常应该有个ipv4的信息&#xff09; 判断原因&#xff1a;可能是之前格式化磁盘驱动的时…...

Unity之PUN2插件实现多人联机射击游戏

目录 &#x1f4d6;一、准备工作 &#x1f4fa;二、UI界面处理 &#x1f4f1;2.1 登录UI并连接PUN2服务器 &#x1f4f1;2.2 游戏大厅界面UI &#x1f4f1;2.3 创建房间UI &#x1f4f1;2.4 进入房间UI &#x1f4f1;2.5 玩家准备状态 &#x1f4f1;2.6 加载战斗场景…...

72_Pandas.DataFrame保存并读取带pickle的系列(to_pickle、read_pickle)

72_Pandas.DataFrame保存并读取带pickle的系列&#xff08;to_pickle、read_pickle&#xff09; 要将 pandas.DataFrame、pandas.Series 对象保存为 pickle 文件&#xff0c;请使用 to_pickle() 方法&#xff0c;并使用 pd.read_pickle() 函数读取保存的 pickle 文件。 在此对…...

Redis哨兵模式和Redis Cluster模式

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容Redis Cluster 模式支持自动故障转移功能吗&#xff1f;Redis Cluster 模式支持自动故障转移功能和哨兵有什么区别&#xff1f;Redis Cluster 模式和哨兵模式&#xff08;Sentinel&#xff09;在自动故障转移方面有一些关键…...

C语言第三十二弹---自定义类型:联合和枚举

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】 目录 1、联合体 1.1、联合体类型的声明 1.2、联合体的特点 1.3、相同成员的结构体和联合体对比 1.4、联合体大小的计算 1.5、联合的⼀个练习 2、枚举类型 …...

milvus upsert流程源码分析

milvus版本:v2.3.2 整体架构: Upsert 的数据流向: 1.客户端sdk发出Upsert API请求。 import numpy as np from pymilvus import (connections,Collection, )num_entities, dim 4, 3print("start connecting to Milvus") connections.connect("default",…...

从原理到实战:深入解析ESD测试标准与设备选型

1. ESD测试的核心原理与行业价值 静电放电&#xff08;ESD&#xff09;就像冬天脱毛衣时噼啪作响的小闪电&#xff0c;但它的破坏力远超你的想象。我曾在某智能手表项目中亲眼目睹&#xff1a;工程师只是随手拿起电路板&#xff0c;屏幕上立刻出现花屏——这就是人体静电导致的…...

保护公司核心测试资产:CANoe CAPL脚本的3种加密方法与硬件绑定实战指南

保护公司核心测试资产&#xff1a;CANoe CAPL脚本的3种加密方法与硬件绑定实战指南 在汽车电子测试领域&#xff0c;CAPL脚本往往承载着企业多年积累的测试逻辑和专有技术。我曾亲眼见证一家供应商因测试脚本泄露导致竞品在三个月内复现其全部测试用例&#xff0c;直接造成数百…...

头歌(educoder)机器学习实战:从购物篮到商业洞察的Apriori算法全流程解析

1. 从购物篮到商业洞察&#xff1a;Apriori算法入门指南 想象你是一家超市的数据分析师&#xff0c;每天面对成千上万条购物记录。如何从这些看似杂乱的数据中发现"啤酒和尿布"这样的黄金组合&#xff1f;这就是关联规则分析的魅力所在。Apriori算法作为最经典的关联…...

告别Excel!用Maple Flow搞定电路容差分析,5分钟生成WCCA报告

硬件工程师的效率革命&#xff1a;用Maple Flow实现WCCA分析的智能跃迁 当电路板上的最后一个电阻焊接完毕&#xff0c;硬件工程师的挑战才刚刚开始。最坏情况电路分析&#xff08;WCCA&#xff09;就像悬在每位设计者头上的达摩克利斯之剑——传统Excel手工计算不仅耗时数日&a…...

Gitleaks介绍(开源的Git仓库敏感信息扫描工具,用于检测代码中是否包含潜在secrets)密钥扫描、敏感信息扫描、自定义规则Regex、SARIF、质量门禁、Trivy、SAST

文章目录使用 Gitleaks 防止代码仓库泄露敏感信息一、什么是 Gitleaks&#xff1f;二、为什么需要 Gitleaks&#xff1f;1. Git 是“永久记录”2. 自动化开发带来的风险3. 安全合规要求三、Gitleaks 的核心能力1. 基于规则的检测&#xff08;Rule-based Detection&#xff09;2…...

ComfyUI-Impact-Pack完整指南:AI图像细节增强的终极解决方案

ComfyUI-Impact-Pack完整指南&#xff1a;AI图像细节增强的终极解决方案 【免费下载链接】ComfyUI-Impact-Pack Custom nodes pack for ComfyUI This custom node helps to conveniently enhance images through Detector, Detailer, Upscaler, Pipe, and more. 项目地址: ht…...

在Windows上安装Android应用的终极解决方案:APK-Installer完整指南

在Windows上安装Android应用的终极解决方案&#xff1a;APK-Installer完整指南 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否曾经在Windows电脑上看到喜欢的An…...

4.9、从CVE-2007-2447到永恒之蓝:Samba漏洞利用的攻防演进

1. Samba服务与SMB协议的前世今生 第一次接触Samba是在2008年的一次企业内网渗透测试中。当时客户要求在不影响业务的情况下&#xff0c;评估文件共享服务器的安全性。当我用nmap扫描到139和445端口时&#xff0c;一个熟悉的"Samba 3.0.24"版本号让我眼前一亮——这不…...

51单片机按键控制LED的两种编程思路对比:数组映射 vs Switch语句,哪种更适合你?

51单片机按键控制LED的两种编程范式深度解析&#xff1a;数组映射与Switch语句的工程实践 当你在深夜调试一块布满LED的51单片机开发板时&#xff0c;是否曾为按键控制逻辑的代码结构纠结过&#xff1f;作为经历过数十个嵌入式项目的开发者&#xff0c;我发现数组映射和switch-…...

ESP32物联网开发终极指南:从零开始构建智能家居环境监测系统

ESP32物联网开发终极指南&#xff1a;从零开始构建智能家居环境监测系统 【免费下载链接】arduino-esp32 Arduino core for the ESP32 项目地址: https://gitcode.com/GitHub_Trending/ar/arduino-esp32 想要打造自己的智能家居环境监测站吗&#xff1f;无需复杂的编程经…...