【操作系统】三、线程

文章目录

线程的概念

线程是一个基本的CPU执行单位,也是程序执行流的最小单位。

线程的属性

同一进程的线程切换

进程内的线程都是共享进程资源的,也就是内存空间地址等都是共享的,线程间切换时只需要切换线程上下文(寄存器的一些信息),不涉及切换内存空间地址和其他系统分配给进程资源,所以开销比较小。

不同进程的线程切换

跨进程线程切换则需要切换寄存器 + 昂贵的地址空间切换 + 其他资源切换

保证切换开销最小的策略

时间片调度与优化
  • 操作系统会给每个线程分配一个时间片 。在一个时间片内,CPU可以连续执行同一个进程内的多个线程,进行多次开销很小的同进程线程切换,直到必须切换到另一个进程为止。
  • 调度器会尽量让属于同一个进程的线程连续运行,以利用地址空间的"热度"(活跃的TLB和缓存),减少昂贵的进程切换次数。
线程模型的设计初衷
  • "开销小"是线程相对于进程的先天优势 。程序员在设计并发程序时,应有意识地将需要频繁通信和协作的任务放在同一进程的多个线程中 ,而不是分散到多个进程。这样,大部分切换都是低开销的线程切换,从而从整体上保证系统开销最小
  • 要获得高性能并发,应优先使用多线程(在同进程内),而非动辄创建多进程。

切换开销最小的实现

  • 通过调度算法,尽量让同进程线程连续运行,减少进程切换的频率。
  • 通过合理的架构设计(使用多线程处理高耦合任务),使程序中大部分并发切换发生在进程内部,从而在整体上最小化系统的切换开销。

线程的实现方式

用户级线程

用户级线程(User-Level Thread,ULT):是由应用程序通过线程库实现,所有的线程管理工作都是由应用程序负责,包括线程切换。

用户级线程中,线程切换可以在用户态下完成,无需操作系统干预。

从用户的角度来看是有多给线程,但实际操作系统是感受不到线程的存在。只是在进程内通过应用程序实现。

优点

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

缺点

当一个用户级线程被阻塞时,整个进程都会阻塞,并发度不高。多个线程不可在多核处理机上做并行处理,本质是一个进程获取时间片后,线程依次执行。

内核级线程

内核级线程(Kernel-Level Thread,KLT):是由操作系统内核直接管理和调度的线程。

线程调度、切换等工作都必须由内核负责,内核级线程的切换需要在核心态下才能完成。

操作系统会为每个内核级线程建立相应的TCB(Thread Control Block,线程控制块),通过TCB对线程进行管理。

优点

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

缺点

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

多线程模型

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

一对一模型

多对一模型

多对多模型

线程的状态和转换

线程的组织与控制

相关推荐
liuyao_xianhui1 小时前
优选算法_判断字符是否唯一_C++
java·开发语言·数据结构·c++·算法·链表
代码雕刻家1 小时前
3.4.Maven-idea集成-导入Maven项目
java·maven·intellij-idea
no_work2 小时前
python-深度学习快速入门实战-数据集和源码
开发语言·人工智能·python·深度学习·神经网络·cnn
Yupureki2 小时前
《C++实战项目-高并发内存池》7.大块内存的申请与释放
服务器·c语言·开发语言·c++·算法·哈希算法
2301_803554522 小时前
c++中的CAS是什么
java·开发语言·c++
河西石头2 小时前
powerconfig告别繁琐配置读写---为C#提供了一个快捷的读写配置文件的API
开发语言·c#·高效读写配置文件·c#配置文件·xml读写
IOT-Power2 小时前
QT 事件驱动架构
开发语言·qt·架构
2401_889884662 小时前
模板代码模块化设计
开发语言·c++·算法
java1234_小锋2 小时前
Java高频面试题:RabbitMQ中有哪几种交换机类型?
java·rabbitmq·java-rabbitmq