操作系统——进程管理

进程管理

进程与线程

进程

进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,它是系统进行资源分配和调度的一个单位。例如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种表格、内存空间、磁盘空间、I/O设备等,然后该进程被放入到进程的就绪队列,进程调度程序选中它,为它分配CPU及其他相关资源,该进程就被运行起来

线程

线程是进程的一个实体,是CPU调度和分配的基本单位,线程自己基本上不拥有系统资源,只拥有一些在运行中必不可少的资源(如程序计数器、一组寄存器和栈),但是,它可以与同属一个进程的其他线程共享进程所拥有的全部资源

在没有实现线程的操作系统中,进程既是资源分配的基本单位,又是调度的基本单位,它是系统中并发执行的单元。而在实现了线程的操作系统中,进程是资源分配的基本单位,而线程是调度的基本单位,是系统中并发执行的单元

引入线程的优点:

  1. 易于调度
  2. 提高并发性。通过线程可以方便有效地实现并发
  3. 开销小。创建线程比创建进程要快,所需要的开销也更少
  4. 有利于多处理器的功能。通过创建多线程,每个线程都在一个处理器上运行,从而实现应用程序的并行,使每个处理器都得到充分运行
进程与线程的区别
  1. 一个线程必定属于也只能属于一个进程;而一个进程可以拥有多个线程并且至少拥有一个线程
  2. 属于一个进程的所有线程共享该进程的所有资源,包括打开文件、创建的Socket等。不同的进程相互独立
  3. 线程又被称为轻量级进程。进程有进程控制块,线程也有线程控制块。但线程控制块比进程控制块小得多。线程间切换代价小,进程间切换代价大
  4. 进程是程序的一次执行,线程可以理解为程序中一个程序片段的执行
  5. 每个进程都有独立的内存空间,而线程共享所属进程的内存空间
程序、进程与线程的区别
  1. 程序:一组指令的有序结合,是静态的指令,是永久存在的

  2. 进程:具有一定独立功能的程序关于某个数据集合上的一次运行活动,是系统进行资源分配和调度的一个独立单元。进程的存在是暂时的,是一个动态概念

  3. 线程是进程的一个实体,是CPU调度和分配的基本单元,是比进程更小的能独立运行的基本单元。本身基本上不拥有系统资源,只拥有一些在运行中必不可少的资源(如程序计数器、一组寄存器和栈)。一个线程可以创建和撤销另一个线程,同一个进程中的多个线程之间可以并发执行

线程同步机制

现在流行的进程线程同步互斥的控制机制,其实是有最原始、最基本的4种方法(临界区、互斥量、信号量和事件)实现的

  1. 临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问。在任意时刻只允许一个线程访问共享资源,如果多个线程试图访问共享资源,那么当有一个线程进入后,其他试图访问共享资源的线程将会被挂起,并一致等到进入邻居区的线程离开,临界在被释放后,其他线程才可以抢占

  2. 互斥量:为协调对一个共享资源的单独访问而设计,只有拥有互斥量的线程,才有权限去访问系统的公共资源,因为互斥量只有一个,所以能够保证资源不会同时被多个线程访问。互斥不仅能实现同一应用程序的公共资源安全共享,还能实现不同应用程序的公共资源安全共享

  3. 信号量:为控制一个具有有限数量的用户资源而设计。它允许多个线程在同一时刻去访问同一资源,但一般需要限制同一时刻访问此资源的最大线程数目

  4. 事件:用来通知线程有一些事件已发生,从而启动后继任务的开始

内核线程和用户线程

内核线程

内核线程的建立和销毁都是由操作系统负责、通过系统调用完成,操作系统在调度时,参考各进程内的线程运行情况做出调度决定。如果一个进程中没有就绪态的线程,那么这个进程也不会被调度占用CPU

用户线程

用户线程指不需要内核支持而在用户程序中实现的线程,其不依赖于操作系统核心,用户进程利用线程库提供创建、同步、调度和管理线程的函数来控制用户线程。

用户线程多见于一些历史悠久的操作系统,如UNIX操作系统,不需要用户态/核心态切换,速度快,操作系统内核不知道多线程的存在,因此一个线程阻塞使得整个进程(包括它的所有线程)阻塞。由于这里的处理器时间片分配是以进程为基本单位的,所以每个线程执行的时间相对减少。

为了在操作系统中加入线程支持,采用了在用户空间增加运行库来实现线程,这些运行库被称为“线程包”,用户线程是不能被操作系统所感知的

引入用户线程的优势:

  1. 可以在不支持线程的操作系统中实现

  2. 创建和销毁线程、线程切换等线程管理的代价比内核线程少得多

  3. 允许每个进程定制自己的调度算法,线程管理比较灵活

  4. 线程能够利用的表空间和堆空间比内核级线程多

用户线程的缺点:

  1. 同一进程中只能同时有一个线程在运行,如果一个线程使用了系统调用而阻塞,那么整个进程都会挂起

  2. 页面失效也会导致整个进程被挂起

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值