[No000038]操作系统Operating Systems -CPU
管理CPU ,先要使用CPU…
CPU 的工作原理
CPU上电以后发生了什么? 自动的取指 — 执行

- CPU 怎么工作?
- CPU怎么管理?
管理CPU 的最直观方法
设好PC 初值就完事!

看看这样做有没有问题? 提出问题

怎么解决?

现在变成了这个样子

多道程序、交替执行,好东西啊!


|
单道程序 |
多道程序 |
|
|
CPU 利用率 |
40/80=50% |
40/45=89% |
|
DEV1 利用率 |
15/80=18.75% |
15/45=33% |
|
DEV2 利用率 |
25/80=31.25% |
25/45=56% |
一个CPU面对多个程序?

一个CPU 上交替的执行多个程序: 并发
怎么做到?
修改寄存器PC 就行了吗?

运行的程序和静态程序不一样了…

引入"进程"概念
运行的程序和静态程序不一样!
- 需要描述这些不一样…(这些不一样就成了进程概念的外延)
- 程序 + 所有这些不一样 -> 一个概念(所有的不一样都表现在PCB 中…)
进程是进行(执行)中的程序
- 进程有开始、有结束,程序没有
- 进程会走走停停,走停对程序无意义
- 进程需要记录ax,bx,… ,程序不用
- …………
多进程图像Multiple Processes…
多个进程使用CPU的图像
如何使用CPU 呢?
- 让程序执行起来
如何充分利用CPU 呢?
- 启动多个程序,交替执行
启动了的程序就是进程,所以 是多个进程推进
- 操作系统只需要把这些进程 记录 好、要按照合理的次序推进(分配资源、进行调度)
- 这就是多进程图像…

多进程图像从启动开始到关机结束
main 中的fork() 创建了第1 个进程
- init 执行了shell(Windows 桌面)
if(!fork()){init();}
shell再启动其他进程
int main(int argc, char * argv[])
{ while(1) { scanf("%s", cmd);
if(!fork()) {exec(cmd);} wait(); } }
一命令启动一个进程,返回shell 再启动其他进程…

多进程图像:多进程如何组织?
有一个进程在执行

有一些进程等待执行

有一些进程再等待某事件

多进程的组织:PCB+ 状态+ 队列
运行 → 等待; 运行 → 就绪; 就绪 → 运行……

- 该图称为 进程状态图
- 它能给出进程生存期的清晰描述
- 它是认识操作系统进程管理的一个窗口
多进程图像:多进程如何交替?
启动磁盘读写;
pCur.state = 'W';
将pCur 放到DiskWaitQueue;
schedule();
schedule()
{
pNew = getNext(ReadyQueue);
switch_to(pCur,pNew);
}
交替的三个部分:队列操作+ 调度+ 切换
就是进程调度,一个很深刻的话题
FIFO?
FIFO 显然是公平的策略
FIFO 显然没有考虑进程执行的任务的区别
Priority?
优先级该怎么设定? 可能会使某些进程饥饿
switch_to(pCur,pNew) {
pCur.ax = CPU.ax;
pCur.bx = CPU.bx;
...
pCur.cs = CPU.cs;
pCur.retpc = CPU.pc;
CPU.ax = pNew.ax;
CPU.bx = pNew.bx;
...
CPU.cs = pNew.cs;
CPU.retpc = pNew.pc; }


多进程图像:多进程如何影响?
多个进程同时在存在于内存会出现下面的问题

解决的办法:限制对地址100 的读写
多进程的地址空间分离: 内存管理的主要内容
进程执行时的100…

- 进程1 的映射表将访问限制在进程1 范围内
- 进程1 根本访问不到其他进程的内容
- 内存管理…
进程带动内存的使用
为什么说进程管理连带内存管理形成多进程图像?

多进程图像:多进程如何合作?
想一想打印工作过程
- 应用程序提交打印任务
- 打印任务被放进打印队列
- 打印进程从队列中取出任务
- 打印进程控制打印机打印

从纸上到实际:生产者− 消费者实例


两个合作的进程都要修改counter


核心在于进程同步(合理的推进顺序)
写counter 时阻断其他进程访问counter


如何形成多进程图像?

- 读写PCB ,OS 中最重要的结构,贯穿始终
- 要操作寄存器完成切换
- 要写调度程序
- 要有进程同步与合作
- 要有地址映射
[No000038]操作系统Operating Systems -CPU的更多相关文章
- [No00003D]操作系统Operating Systems信号量的代码实现Coding Semaphore &死锁处理Deadlock
操作系统Operating Systems信号量的代码实现Coding Semaphore &死锁处理Deadlock 可以操刀了—从纸上到实际 从Linux 0.11 那里学点东西… 读磁盘 ...
- [No00003C]操作系统Operating Systems进程同步与信号量Processes Synchronization and Semaphore
操作系统Operating Systems进程同步与信号量Processes Synchronization and Semaphore 进程合作:多进程共同完成一个任务 从纸上到实际:生产者− − ...
- [No00003A]操作系统Operating Systems 内核级线程Kernel Threads内核级线程实现Create KernelThreads
开始核心级线程 内核级线程对多核的支持怎么样? 和用户级相比,核心级线程有什么不同? ThreadCreate 是系统调用,内核管理TCB ,内核负责切换线程 如何让切换成型? − − 内核栈,TCB ...
- [No000037]操作系统Operating Systems操作系统历史与硬件概况History of OS & Summaries!
培根:读史使人明智 操作系统的简史 (1955-1965) 计算机非常昂贵,上古神机IBM7094 ,造价在250万美元以上 计算机使用原则:只专注于计算 批处理操作系统(Batch system) ...
- [No000031]操作系统 Operating Systems 之Open the OS!
从打开电源开始… 这神秘的黑色背后发生着什么?… 打开电源,计算机执行的第一句指令什么? 计算模型(图灵机) ⇒ 我们要 关注 指针IP 及其 指向的内容 看看x86 PC (1) 刚开机时CPU 处 ...
- [No000036]操作系统Operating Systems系统调用的实现System_Call
实现一个whoami 系统调用 系统调用的直观实现 问题+直观想法… 用户程序调用whoami, 一个字符串"systemcall "放在操作系统中(系统引导时载入) ,取出来打印 ...
- [No000039]操作系统Operating Systems用户级线程User Threads
多进程是操作系统的基本图像 是否可以资源不动而切换指令序列? 进程 = 资源 + 指令执行序列 线程: 保留了并发的优点,避免了进程切换代价 实质就是映射表不变而PC 指针变 多个执行序列+ 一个地址 ...
- Modern Operating Systems(Ⅰ)——2014.12.15
进程 进程模型 进程就是一个正在执行的程序的实例 值得注意的是,若一个程序运行了两遍,则算作两个进程 创建进程 在通用系统中,有四种主要事件导致进程的创建 ①系统的初始化 ②执行了 正在 ...
- Operating Systems (COMP2006)
Operating Systems (COMP2006) 1st Semester 2019Page 1, CRICOS Number: 00301JOperating Systems (COMP20 ...
随机推荐
- Phonegap之ios对iPhone6和Plus的闪屏适配 -- xmTan
故事的发生起于,由于老板强烈要求app在iPhone6和5有一样的工具栏,然后前端妹子用@media为iPhone6和Plus做了样式适配.然后问题来了,竟然奇葩的发现@media样式只对iPhone ...
- TimeUnit 使用
TimeUnit是java.util.concurrent包下面的一个类,表示给定单元粒度的时间段 主要作用 时间颗粒度转换 延时 常用的颗粒度 TimeUnit.DAYS //天 TimeUnit. ...
- IOS开发——01_第一个OC程序
本文目录 一.新建Xcode项目 二.运行项目 注:建议先学习C语言, 如果你还没有编程经验,看不懂的地方可以在评论区提出,本文使用的为Xcode6.1版本,与之前版本会有所差异,但总体不变. 另:还 ...
- Android 常用数据适配器ArrayAdapter
接着上篇文章<Android 采用Layout Inflater创建一个View对象>,本文采用常用数据适配器ArrayAdapter 新建项目后,在layout文件夹下新建list_it ...
- iOS---去除url中的反斜扛
// NSString * str = [url stringByReplacingOccurrencesOfString:@"\\/" withString:@" ...
- iOS常见三方总结(更新中)
常用的三方积累 MJExtention SSZipArchive 用于解压与压缩文件 地址:https://github.com/ZipArchive/ZipArchive ps:比较奇葩,githu ...
- Swift中的部分更新与旧版的区别
1. 函数中的外部变量名取消 “#”方式,仅能用直接命名方式 错误 func swift(#str :NSString){} 正确 func swift(str str :NSString){} 2. ...
- Entity Framework 4.1 - Code First 指定外键名称
Entity Framework 4.1 中,生成外键的方式有以下几种: 1-指定导航属性,会自动生成外键,命名规则为:“表名_主键名”2-默认情况下与导航属性的主键名称相同的字段会自动被标记为外键, ...
- Sandcastle----强大的C#文档生成工具
最近客户索要产品的二次开发类库文档,由于开发过程中并没有考虑过此类文档,而且项目规范比较,持续时间比较长,经手人比较多,还真是麻烦,如果人工制作文档需要是一个比较大的工程.还好有这个文档生成工具,能够 ...
- 使用虚拟信用卡认证openshift铜牌计划
"铜牌计划(bronze)"是OpenShift推出的一项免费计划,这个计划能为你提供更多的免费便利,主要就是可以自己绑域名加SSL证书和应用即使24小时没人访问也不关机了.说这个 ...