[面试直通版]操作系统核心之进程、线程与协程(上)_如何隔离不同程序需要使用的计算机资源 操作系统如何进行不同程序的调度 操作系(1)

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

  • 多用户(不仅指人,如多软件,多进程,多系统)共享
  • 能及时调试程序
  • 资源利用率提升
    • 多道程序设计
  • 早期的批处理系统只能一次处理一个任务
  • 多道程序设计使得批处理系统可以一次处理多个任务
  • 多道程序设计是指在计算机内存中同时存放多个程序
  • 多道程序在计算机的管理程序之下相互穿插运行
  • 对多道程序的管理是现代操作系统的重要功能
  • 所以多道程序设计之后的操作系统的形态为:
  • 用户无需面向硬件接口编程,利用操作系统来管理硬件资源
  • 如:
  • IO设备管理软件,提供读写接口
  • 文件管理软件,提供操作文件接口
  • 操作系统实现了对计算机硬件资源的管理和抽象
  • 多道程序设计可能会遇到的问题
  • 如何隔离不同程序需要使用的计算机资源?
  • 操作系统如何进行不同程序的调度?
  • 操作系统如何提升计算机资源的利用率和复用率?
  • 答案:操作系统需要进程
    • 进程
  • 为什么需要进程
  • 进程是系统进行资源分配和调度的基本单位
  • 进程作为程序独立运行的载体保障程序正常执行
  • 进程的存在使得操作系统资源的利用率大幅提升
  • 进程的形态
  • 在主存里,进程也是一段连续存储的空间,这个空间称为进程控制块(PCB)
  • 其中含有很多重要的信息:
  • 标识符,状态,优先级,程序计数器,内存指针,上下文数据,IO状态信息,记账信息等等
  • 标识符
  • 标识符唯一标记一个进程,用于区别其它进程
  • 状态
  • 标记进程的进程状态,如运行态,阻塞态
  • 程序计数器
  • 指向进程即将被执行的下一条指令的地址
  • 内存指针
  • 程序代码,进程数据相关指针
  • 上下文数据
  • 存储的是进程执行时处理器存储的数据
  • IO状态信息
  • 存储的是被进程IO操作所占用的文件列表
  • 记账信息
  • 存储的是进程所使用的CPU时间,时钟数总和等
  • 以上的都能归为4类:
  • 1.进程标识符
  • 2.进程处理机状态
  • 3.进程调度信息
  • 4.进程控制信息
  • 进程控制块(PCB)是用于描述和控制进程运行的通用数据结构
  • 用于记录进程当前状态和控制进程运行的全部信息
  • PCB使得进程是能够独立运行的基本单位
  • 由于PCB是操作系统进行调度经常会被读取的信息
  • 所以PCB是常驻内存的,存放在系统专门开辟的PCB区域内
    • 进程状态模型

  • 典型问题:
  • 简述阻塞、非阻塞、同步、异步
  • 简述为什么进程会发生阻塞
  • 以下内容带您一步步了解
    • 五状态模型
  • 典型的进程的状态分别有创建状态,就绪状态,终止状态,阻塞状态,执行状态
  • 就绪状态
  • 当进程被分配到除CPU以外所有必要的资源后
  • 只要再获得CPU的使用权,就可以立即运行,随时可以被调度去执行
  • 也就是其它资源都准备好了,只差CPU资源的状态为就绪状态
  • 执行状态
  • 进程获得CPU,其程序正在执行称为执行状态
  • 在单处理机中,在某个时刻只能有一个进程是处于执行状态
  • 阻塞状态
  • 进程因某种原因如:其它设备未就绪而无法继续执行
  • 从而放弃CPU的状态称为阻塞状态
  • 各状态之间关系
  • 从就绪状态到执行状态就是经过进程调度(也就是分配CPU资源)
  • 从执行状态到就绪状态就是时间片用完了
  • 从执行状态到阻塞状态主要是某些资源没有就绪,如IO请求未完成
  • 从阻塞状态到就绪状态就是把之前未就绪的完成了,如IO完成
  • 创建状态
  • 对于创建状态操作系统需要很多准备工作
  • 主要是分配PCB(进程控制块),再把这些数据插入就绪队列
  • 创建进程时拥有PCB但其它资源尚未就绪的状态称为创建状态
  • 终止状态
  • 在终止状态,操作系统主要做一些清理工作
  • 进程结束由系统清理或者归还PCB的状态称为终止状态
    • 阻塞,非阻塞,同步,异步
  • 阻塞典型的就是一个IO过程
  • IO过程从调用到返回会经历一段时间
  • 因为通常外围设备如磁盘,网卡在读写数据时并没有CPU那么快
  • 这段时间进程的状态就称为阻塞状态
  • 非阻塞也例一个IO过程
  • 但是在调用时会直接返回,转而去执行别的工作,等IO完成之后,由别的设备通知它说这个过程已经完成,这时进程才返回IO的任务去读取这个数据
  • 因为进程它是一直在运行的,没有进行等待
  • 这个过程就称为非阻塞状态
  • 由此延伸出同步和异步的概念
  • 阻塞状态这边属于同步的过程
  • 因为它的准备过程需要一段时间,进程在这段时间并没有干任何事情,而是同步地等待
  • 一直等待到数据进行返回才接收这个数据进行后续的工作,是一个同步等待的过程
  • 异步是相对于同步而言的
  • 非阻塞状态这边就有异步的过程
  • 因为进程它在IO之后没有进行同步地等待,而是转而去干别的事情了
  • 并且等IO过程准备好之后进行通知,进程在接收到这个通知后才进行切换回来来读这个数据
  • 这个过程因为数据的准备以及进程运行别的事情是并行地在执行的
  • 这就能称它的IO读取是异步的过程
  • 同步和异步主要是通过消息的通知机制去理解的
  • 阻塞里的通知是一直准备地通知,所以是同步

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

3fab5e56a57acb)**

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值