线程概念和多线程模型

作者: HRADPX | 来源:发表于2019-07-22 12:29 被阅读13次

1 线程概念

  在没有线程之前,系统中进程之间是并发执行的,但是进程是程序的一次执行,即一个进程只能串行执行一系列程序,如使用QQ视频,发送文件和文字聊天这三件事就不可能并发执行,为此引入了线程,让一个进程内可以并发处理多个任务(如QQ视频、文字聊天,发送文件),所以线程让进程并发成为了可能。
  线程是一个最基本的CPU执行单元,是程序执行流的最小单位。线程实现了进程内部的并发,进一步提高了体从的并发度。

2 线程引入后的变化

  进程是资源分配的基本单位,线程是调度的基本单位。
  线程让进程内部也能并发执行,提高了并发度。
  如果同一个进程内的线程切换,不需要切换进程环境,系统开销小。

3 线程属性

  (1) 同一进程的不同线程间共享进程的资源。由于共享内存地址空间,同一进程中线程间通信甚至不需系统干预。
  (2) 每个线程都有一个线程ID,线程控制块(TDB)。
  (3) 线程几乎不拥有系统资源。
  (4) 多CPU计算机,各个线程可占用不同的CPU。
  (5) 同一个进程的线程切换,不会引起线程切换。不同进程中的线程切换回引起线程切换。切换进程内的线程由于不需要切换进程环境,系统开销小。

4 线程的实现方式

  线程实现方式:用户级线程和内核级线程。

  4.1 用户级线程

  用户级线程由程序通过线程库实现。所有线程管理工作都是由应用程序负责(包括线程切换)。用户线程中,线程切换可以在用户态下即可完成,无需操作系统干预。

  在用户看来,是有多个线程,但是操作系统内核看来,并意识不到线程的存在。用户线程对用户不透明,对操作系统透明。

  注:在计算机中,从某个角度看不到的特性称该特性是透明的,操作系统看不到用户线程,所以对操作系统是透明的。

  4.2 内核级线程

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

  4.3 组合方式

  在同时支持用户线程和内核线程的系统中,可以采用二者组合的方式,将n个用户线程映射到m个内核线程上(n≥m)。
  由于操作系统只看得见内核级线程,所以内核级线程才是处理机分配的单位。
  由于操作系统只看得见内核级线程,所以内核级线程才是处理机分配的单位。


  所以对于上图,只有两个内核级线程,所以即使在4核处理机的计算机上运行,也最多只能被分配到两个核,最多只能有两个用户线程并行执行,因为内核级线程才是处理机分配的单位。

5 多线程模型

  5.1 多对一模型

  多对一模型:多个用户级线程映射到一个内核级线程,每个用户进程对应一个内核级线程。



  优点:用户级线程切换在用户空间就可以完成,不需要切换到核心态,线程管理的系统开销小,效率高。
  缺点:当一个线程被阻塞后,整个进程就会被阻塞,并发度不高。多个线程不可以在多核处理机上并行运行。

  5.2 一对一模型

  一对一模型:一个用户线程映射到一个内核线程。



  优点:当一个线程被阻塞,别的线程还可以继续执行,并发能力强。多线程在多核处理机上可以并行执行。
  缺点:一个用户进程会占用多个内核级线程。线程切换由操作系统内核完成,需要切换到核心态,开销大。

  5.3 多对多模型

  多对多模型:n个用户线程映射到m个内核级线程,每个用户进程对应m个内核级线程。



  多对多模型综合了上面两种模型的优点,克服了多对一模型并发度不高的缺点,又克服了一对一模型中一个用户进程占用内核级线程,开销大的缺点。

6 小结

  本文完


  如发现错误,请指正!!!

相关文章

  • 三、操作系统之线程

    前言 什么是线程 引入线程的原因 线程的概念 线程和进程的关系 线程结构 线程有点 多线程模型 用户线程和内核线程...

  • 线程概念和多线程模型

    1 线程概念 在没有线程之前,系统中进程之间是并发执行的,但是进程是程序的一次执行,即一个进程只能串行执行一系列程...

  • ios多线程编程简介

    iOS的多线程跟其他像c语言创建的线程的概念不太一样。 多线程模型为一个个block组成的queue来实现多线程编...

  • Java篇-多线程

    多线程的概念已经写过很多了,java的多线程的概念和之前讲解的 OC 与 python多线程相同,这里就不再赘述了...

  • iOS多线程.md

    2018-05-22 iOS多线程-概念iOS多线程:『pthread、NSThread』详尽总结 多线程-概念图...

  • Reactor线程模型及其在Netty中的应用

    什么是Reactor线程模型 Java中线程模型大致可以分为: 单线程模型 多线程模型 线程池模型(executo...

  • iOS多线程技术方案

    目录 一、多线程简介 1、多线程的由来2、耗时操作的模拟试验3、进程和线程4、多线程的概念及原理5、多线程的优缺点...

  • 我看谁还不懂多线程之间的通信+基础入门+实战教程+详细介绍+附源

    一、多线程之间的通信(Java版本) 1、多线程概念介绍 多线程概念 在我们的程序层面来说,多线程通常是在每个进程...

  • 多线程

    进程/线程/串行/多线程的概念、原理以及多线程的优劣/多线程在iOS的应用和使用方式请参考CC老师系列文章:01 ...

  • 多线程

    内存耗时问题 线程是进程的基本执行单元 多线程的优缺点 优点: 缺点: 多线程的作用: 多线程中同步和异步的概念 ...

网友评论

    本文标题:线程概念和多线程模型

    本文链接:https://www.haomeiwen.com/subject/envilctx.html