Operating System-Thread(3)用户空间和内核空间实现线程

本文主要内容:

  1. 操作系统用户空间和内核空间简介
  2. 在用户空间实现线程
  3. 在内核空间实现线程
  4. 用户空间和内核空间线程混合使用

一、用户空间和内核空间简介

用户空间:User space,内核空间:Kernel Space。这两个是操作系统的重要概念之一,今天为了线程做一下简单的介绍:

  1. 内核空间用于运行操作系统核心组件,比如内存管理组件,IO交互组件,文件管理、中断管理组件等,同时驱动程序(Driver)也运行在内核空间。
  2. 用户空间,用于运行普通应用程序。

示意图:

二,在用户空间实现线程

用户空间的线程由进程通过一些已有的Library进行创建,非系统调用(system call)内核对此毫无知晓。实现如下图所示。

在用户空间实现线程,线程运行在运行时系统中(run-time system)。内核对此一无所知,对于内核来说,它这是在处理一个单线程的进程而已。在用户空间实现线程时,每一个进程针对自己的线程维护了一个线程表(Thread Table),该表保存了线程运行的各种变量,比如寄存器,PC,状态等等,线程表用进程的运行时系统来维护,当一个线程被block,她的当前运行状态会被保存在线程表中,当再次启动时,也会读取线程表中已经保存的状态,从该状态进行再次运行。

2.1 优势

  1. 线程的创建有run-Time system通过调用现有的Library的Procedure完成,创建和销毁进程的开销非常小。
    因为内核对线程没有感知,用户空间的线程可以运行在不支持线程的操作系统中
  2. 因为线程由同一个运行时进行维护,在同一个进程内部,线程的切换没有必要和内核大交道,所以线程之间的切换的开销非常小,没有Context Switch,也没有内存缓存的刷新重置。
  3. 用户空间的线程可以自定义调度算法,程序员完全可以自己写一套针对自己程序的线程调度算法

2.2  劣势

  1. 因为对于内核来说,不管进程里面有多少个线程,内核任然按照单线程进程来处理这个进程,所以统一时间一个进程里面只能有一个线程运行,就算有多个cpu空闲,也只能有一个线程运行,所以无法最大限度的使用资源
  2. 当然由于只能有一个线程运行,当某一个线程被block后,整个进程都会被block。
  3. 对于单进程的系统,用户态的线程如果有一个启动,就会永远运行,无法被切换到另外一个线程,这里还是与第一条有关,对于CPU来说,这个进程就只有一个线程,另外因为是单进程,也就不会有中断(trap、Interrupt)让cpu切换到其他进程的请求。当然这个问题用户可以实现自己的算法进行调度和改善(在run-time system中实现)

三、在内核空间实现线程

内核空间的线程全部有操作系统内核创建,实现如下图所示。

内核线程同样有线程表(Thread table),不过这个线程表是保存在内核中,其功能和用户空间线程表的功能一样,都是用于保存线程的数据。线程的调度由操作系统内核来实现。

内核线程和用户空间线程基本从性能各方面来说基本是相反地

3.1 优势

  1. 线程表包含所有进程的线程,所有一个进程的可能有多个线程同时在多个cpu上同时运行
  2. 一个线程被block不会导致整个进程被block,CPU会看是不是有其他线程可以运行。

3.2 劣势

  1。创建线程消耗非常大,需要在用户空间和内核之间切换。

  2。当然发生线程的Context切换时,程序也要从用户态和内核态之间互相切换,开销大

四、用户空间和内核空间线程混合使用

上面的两种线程的实现方式都有明显的优缺点,最好的方案其实就是将两者结合,一个程序可以既有用户空间的线程,也可以用内核空间的线程。

具体实现方式是,内核线程可以在其之上有一部分用户空间的线程。内核只调度内核的线程。

至于什么样的比例,怎么实现。 又回到程序=数据结构+算法这个话题了。。。

时间: 2024-10-13 12:15:09

Operating System-Thread(3)用户空间和内核空间实现线程的相关文章

经典的线程池--用户空间与内核空间实现的对比

经典的线程池模型是一组线程抢一个资源链表的模型,程序启动了一组线程,让它们等待信号waitQ的到来.同时又初始化一个资源链表,当某个线程往资源链表中添加一个资源时,它同时使用信号通知线程池.线程池中的线程接到信号后,就从资源链表中取出资源进行处理. 接下来,我们先来观察一下用户空间线程池的创建过程吧! 1 int 2 init (xlator_t *this) 3 { 4 iot_conf_t *conf = NULL; 5 int ret = -1; 6 int i = 0; 7 8 if (

Linux系统调用详解(如何从用户空间进入内核空间)

系统调用概述 计算机系统的各种硬件资源是有限的,在现代多任务操作系统上同时运行的多个进程都需要访问这些资源,为了更好的管理这些资源进程是不允许直接操作的,所有对这些资源的访问都必须有操作系统控制.也就是说操作系统是使用这些资源的唯一入口,而这个入口就是操作系统提供的系统调用(System Call).在linux中系统调用是用户空间访问内核的唯一手段,除异常和陷入外,他们是内核唯一的合法入口. 一般情况下应用程序通过应用编程接口API,而不是直接通过系统调用来编程.在Unix世界,最流行的API

用户空间与内核空间,进程上下文与中断上下文[总结]

用户空间与内核空间,进程上下文与中断上下文[总结] 最近有研究到zabbix监控,就得清楚cpu各个指标的含义, 1,简单回顾下cpu及计算机组成: 计算机五大部件: 运算器 控制器 存储器 输入/输出设备. 2,cpu 进程的内核态和用户态 我们知道现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32次方).操心系统的核心是内核,独立于普通的应用程序,可以访问受保护的内存空间,也有访问底层硬件设备的所有权限.为 了保证用户进程不能直接操作内核,

如何看待Linux操作系统的用户空间和内核空间

作为中央核心处理单元的CPU,除了生产工艺的不断革新进步外,在处理数据和响应速度方面也需要有权衡.稍有微机原理基础的人都知道Intel X86体系的CPU提供了四种特权模式ring0~ring3,其中ring0特权最高,ring3的特权最低,之所以要做这样的区分一个主要目的是保护资源,通俗来讲要保护的资源无非就是"内存.I/O端口以及执行特殊机器指令的能力".任何一个时刻,x86 CPU都是在一定的特权模式下运行.同样,对于ARM体系的CPU 一共有七种运行模式,分别是:用户模式(us

Linux内存管理--用户空间和内核空间【转】

本文转载自:http://blog.csdn.net/yusiguyuan/article/details/12045255 关于虚拟内存有三点需要注意: 4G的进程地址空间被人为的分为两个部分--用户空间与内核空间.用户空间从0到3G(0xc0000000),内核空间占据3G到4G.用户进程通常情况下只能访问用户空间的虚拟地址,不能访问内核空间的虚拟地址.例外情况只有用户进程进行系统调用(代表用户进程在内核态执行)等时刻可以访问到内核空间. 用户空间对应进程,所以每当进程切换,用户空间就会跟着

用户空间和内核空间通讯之【proc文件系统】

今天我们介绍另一种用户内核空间通信的方法:proc文件系统. proc文件系统作为linux提供的一种虚拟文件系统并不占用实际外围存储空间,它仅存在于内存中,系统断电即消失.proc文件系统最开始的设计主要是为满足内核向用户态进程报告其状态而设计,并没有为输入做规定和说明.随着发展,现在的proc文件系统已经演变成一个"用户-内核"空间半双工的通信方式了(虽然目前已经开始有点混乱了,但某些早期开发的软件代码中还在继续使用这个文件系统).用户不但可以从proc文件系统中读取内核的相关状态

用户空间和内核空间通讯之【Netlink 上】

原文地址:用户空间和内核空间通讯之[Netlink 上] 作者:wjlkoorey258 引言 Alan Cox在内核1.3版本的开发阶段最先引入了Netlink,刚开始时Netlink是以字符驱动接口的方式提供内核与用户空间的双向数据通信:随后,在2.1内核开发过程中,Alexey Kuznetsov将Netlink改写成一个更加灵活.且易于扩展的基于消息通信接口,并将其应用到高级路由子系统的基础框架里.自那时起,Netlink就成了Linux内核子系统和用户态的应用程序通信的主要手段之一.

用户空间和内核空间通讯之【Netlink 中】

原文地址:用户空间和内核空间通讯之[Netlink 中] 作者:wjlkoorey258 今天我们来动手演练一下Netlink的用法,看看它到底是如何实现用户-内核空间的数据通信的.我们依旧是在2.6.21的内核环境下进行开发. 在</usr/include/linux/netlink.h>文件里包含了Netlink协议簇已经定义好的一些预定义协议: 点击(此处)折叠或打开 #define NETLINK_ROUTE        0    /* Routing/device hook    

【转】linux 用户空间与内核空间——高端内存详解

摘要:Linux 操作系统和驱动程序运行在内核空间,应用程序运行在用户空间,两者不能简单地使用指针传递数据,因为Linux使用的虚拟内存机制,用户空间的数据可能被换出,当内核空间使用用户空间指针时,对应的数据可能不在内存中.用户空间的内存映射采用段页式,而内核空间有自己的规则:本文旨在探讨内核空间的地址映射. Linux内核地址空间划分 通常32位Linux内核虚拟地址空间划分0~3G为用户空间,3~4G为内核空间(注意,内核可以使用的线性地址只有1G).注意这里是32位内核地址空间划分,64位