操作系统--多进程管理CPU

一.cpu管理直观做法

最只管想法cpu循环取址执行,所以只需要设好pc初值即可


存在问题:io会占用时间长,导致cpu利用率低.

所以需要不停切换,执行多个程序,也就是并发.
但是在切换的时候,除了记录返回地址,还要记录当前执行程序运行时刻(也就引入进程),就像人看书一样有人打扰,需要做个记号,下次接着看.使用的是PCB(Process Control Block)的数据结构来记录进程信息,这是操作系统中最重要的结构.


总结:用多进程管理cpu.

二.多进程图像

                   
1.多进程组织:

 采用的是PCB+状态+队列的方式(类似银食堂排队,阻塞状态类比忘记带饭卡了,就将阻塞态放入就绪态).

  

2.多进程交替:

2.1进程调度

比如FIFO(就像食堂排队),存在问题就是优先级怎么设定?后面在具体介绍.

2.2进程切换

利用PCB存储信息与恢复信息.

2.3.多进程影响:

由于同时放在内存中,可能导致不同进程内存共用,导致程序崩溃.
解决办法:需要对进程进行内存管理,采用映射表,将不同进程地址对应的物理地址区分开.

3.多进程合作:

将进程放入队列里,按需索取.
存在问题:由于交替执行,可能同一位置,被不同进程看见,典型例子:生产者和消费者进程.所以在多进程合作时,需要给某些属性上锁,不能被任意进程访问.


参考:

操作系统_哈尔滨工业大学_中国大学MOOC(慕课)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/493051.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

脱裤子放屁,多此一举

脱裤子放屁,多此一举.转载于:https://www.cnblogs.com/zhangzujin/p/3892468.html

胶囊网络、边缘计算:2018年13个最新人工智能发展趋势

来源:亿欧智库摘要: 美国知名研究机构CB Insights的报告《2018年必看的人工智能热门趋势》,对AI行业发展现状进行了深入研究剖析,并给出了2018年AI领域最值得关注的13个前沿发展趋势。趋势一:新蓝领的工作——机器人保…

清空输入缓冲区fflush()

转自&#xff1a;http://blog.csdn.net/21aspnet/article/details/174326 scanf( )函数可以接收输入的换行符&#xff0c;\n,(asci为10)&#xff0c;利用函数fflush(stdin),可以清空输入内存缓冲区。 // function name fflush // 清空一个流 ,2014--03--29 #include <std…

操作系统--用户级线程与内核级线程

一.多进程是操作系统基本图像 进程都是在内核进行 二.用户级线程 2.1线程引入 可以切指令不切表&#xff0c;也就是资源不动&#xff0c;指令执行分开&#xff0c;更加轻量化&#xff0c;从而提高效率&#xff0c;保留并发优点&#xff0c;避免进程切换代价&#xff0c;也就…

“新视野”和“最远点”的约会

NASA 设想的2014 MU69 太空岩石 来源&#xff1a;中国科学报当新年香槟将陌生人聚在一起时&#xff0c;一种不同的聚会正在外太阳系进行。在距地球近65亿公里的地方&#xff0c;美国宇航局&#xff08;NASA&#xff09;“新视野”号探测器创下了寻访迄今最遥远世界的纪录。这场…

C语言里的写文件

转载自&#xff1a;http://blog.csdn.net/shuimuzhiyuan/article/details/6908335 部分转载自&#xff1a;http://blog.csdn.net/lijun5635/article/details/13095883 一 、fopen()函数中第一个形式参数表示文件名, 可以包含路径和文件名两部分。如: "B:TEST.DAT"…

操作系统--内核级线程实现

五段论 &#xff1a; 进入内核靠的是中断&#xff0c;fork是创建系统进程调用&#xff0c;进程由资源&#xff0b;执行序列组成&#xff0c;而创建执行序列其实就是创建线程&#xff0e; TSS:任务结构段 参考&#xff1a; 操作系统_哈尔滨工业大学_中国大学MOOC(慕课)…

一文看尽2018全年计算机视觉大突破

来源&#xff1a;极市平台摘要&#xff1a;计算机视觉领域同样精彩纷呈&#xff0c;与四年前相比GAN生成的假脸逼真到让人不敢相信&#xff1b;新工具、新框架的出现&#xff0c;也让这个领域的明天特别让人期待……2018&#xff0c;仍是AI领域激动人心的一年。计算机视觉领域同…

怎样清空输入缓冲区里的内容

参考自&#xff1a;http://blog.csdn.net/devil_2009/article/details/6364759 fflush()的作用是用来刷新缓冲区&#xff0c;fflush(stdin)刷新标准输入缓冲区&#xff0c;把输入缓冲区里的东西丢弃&#xff1b;fflush(stdout)刷新标准输出缓冲区&#xff0c;把输出缓冲区里的东…

leetcode BFS(python+c++)

1.最小基因变化 思路&#xff1a;bfs搜索回溯 python: class Solution:def minMutation(self, start: str, end: str, bank: List[str]) -> int:library [A,C, G,T]queue [start]num 0vis set()while queue:size len(queue)for i in range(size):cur queue.pop(0)i…

cocos2dx 父元素影响子元素

如果a中又b。 设置a的scaleX&#xff0c;a->getboudingbox会变化&#xff0c;contentsize不变化 子元素显示方面也会变化&#xff0c;同样的缩放比例。 子元素和父元素一起变化的属性还有&#xff0c;rotation/skewx/color 子元素不喝父元素一起变化的属性有&#xff1a;opa…

北欧小国的宏大AI实验: 让1%的人口接受人工智能培训

编译&#xff1a; 机器之能 微胖摘要&#xff1a;芬兰希望在人工智能的实际应用方面占据一席之地&#xff0c;成为世界领先国家。2017 年 10 月&#xff0c;芬兰成为欧盟第一个将国家人工智能战略付诸实施的国家。在 2018 年 6 月发布的第二份报告中&#xff0c;政府估计&#…

形象理解矩阵操作

1.矩阵和向量线性变换 线性变换可看着是对空间的挤压伸展。 也就是看成把向量中的值对矩阵列向量加权 ,在对向量求和 2.矩阵和矩阵的线性变换 矩阵左乘就是对行向量操作&#xff0c;矩阵右乘就是对列向量操作&#xff0e; 可以将其中一个矩阵看成是多个列向量,在拆开对剩下矩…

C/C++中system()函数详解

转载自&#xff1a;http://hi.baidu.com/519378007/item/5c49bb05e23728dbdce5b0e7 windows下system () 函数详解  windows操作系统下system () 函数详解&#xff08;主要是在C语言中的应用&#xff09;  函数名: system 功 能: 发出一个DOS命令 用 法: int system(char *c…

坑爹的uint32_t

首先看看下面这段程序&#xff1a; uint32_t compare 10&#xff1b; for (uint32_t i compare; i > 0; --i) { .......... } 这是一段比较危险的程序&#xff0c; 当 i的值变为 -1的时候&#xff0c;其实由于i是一个非负数整形&#xff0c;强制类型转换后&#xff0c;i又…

leetcode双指针(python与c++)

1.字符串的排列 思路:双指针滑动窗口 python: class Solution:def checkInclusion(self, s1: str, s2: str) -> bool:dict_{}for i in s1:dict_[i] dict_.get(i,0)1# # print(dict_:,dict_)left,right 0,0length 0minlen float(inf)res while right<len(s2):# 向右…

scanf( )函数的返回值

当从键盘连续进行输入时用while&#xff0c;但是程序自己不会通过正常的输入结束。 scanf("%d%d",&a, &b); 如果a和b都被成功读入&#xff0c;scanf()的返回值是2 如果只有a被成功读入或者只有b被成功读入&#xff0c;scanf()的返回值为1 如果a和b都未被…

之前接触过的测试的相关工具

比较出名的lr之类的就不记录了&#xff0c;只是记录一下之前安全测试相关的一些工具&#xff1a; 1.appscan&#xff0c;网页漏洞扫描工具 2.webscarab&#xff0c;可以拦截和修改浏览器与服务器之间发送的数据 3. httpwatch&#xff0c;可以分析浏览器和服务器之间的数据交互 …

CSAPP-计算机漫游

一.编译系统的工作流程: test.cpp #include <iostream> using namespace std; int main() { //hahha cout<<"hello world"<<endl; return 0; }直接生成可执行程序test g -o test test.cpp 深入解析生成可执行程序test的过程 1.g -E test.cpp &…

2-SAT !!

打算这几天搞2-sat了&#xff0c;好好看看这几个博客 再刷十来个题目 gogo&#xff01;&#xff01; http://blog.csdn.net/jarjingx/article/details/8521690 坑在这里&#xff0c;好好填吧&#xff01; poj 3207 poj 3683 poj 3678 poj 3648 poj 2723 poj 2749转载于:https:/…