美文网首页我的收藏
多进程的实现原理-多道技术

多进程的实现原理-多道技术

作者: 我爱学python | 来源:发表于2019-07-21 16:00 被阅读45次

1.操作系统

​ 位于应用软件和硬件设备之间,本质是一个软件

核心作用:

1.为用户屏蔽了复杂繁琐的硬件接口;为应用程序提供了清晰易用的系统接口

2.将用用程序对硬件资源的竞争变得有序

操作系统与应用程序的区别:

1.操作系统是受保护的,无法被用户修改

2.大型:仅内核代码量达上百万行

3.长寿,一旦完成,不会重写,只会有所改进

2. 操作系统发展史

第一代计算机(1940-1945):真空管和穿孔卡片

特点:

没有操作系统的概念

所有的程序设计都是直接操控硬件

工作过程:

程序员在墙上的机时表预约一段时间,然后程序员拿着他的插件版到机房里,将自己的插件板街道计算机里,这几个小时内他独享整个计算机资源,后面的一批人都得等着(两万多个真空管经常会有被烧坏的情况出现)。

后来出现了穿孔卡片,可以将程序写在卡片上,然后读入机而不用插件板

优点:

程序员在申请的时间段内独享整个资源,可以即时地调试自己的程序(有bug可以立刻处理)

缺点:

浪费计算机资源,一个时间段内只有一个人用。

第二代计算机(1955-1965):晶体管和批处理系统

第二代如何解决第一代的问题/缺点:

1.把一堆人的输入攒成一大波输入,

2.然后顺序计算(这是有问题的,但是第二代计算也没有解决)

3.把一堆人的输出攒成一大波输出

现代操作系统的前身:(见图)

优点:批处理,节省了机时

缺点:

1.整个流程需要人参与控制,将磁带搬来搬去(中间俩小人)

2.计算的过程仍然是顺序计算-》串行

3.程序员原来独享一段时间的计算机,现在必须被统一规划到一批作业中,等待结果和重新调试的过程都需要等同批次的其他程序都运作完才可以(这极大的影响了程序的开发效率,无法及时调试程序)

第三代计算机(1965-1980):集成电路芯片和多道程序设计

第三代计算机的操作系统广泛应用了第二代计算机的操作系统没有的关键技术:多道技术

cpu在执行一个任务的过程中,若需要操作硬盘,则发送操作硬盘的指令,指令一旦发出,硬盘上的机械手臂滑动读取数据到内存中,这一段时间,cpu需要等待,时间可能很短,但对于cpu来说已经很长很长,长到可以让cpu做很多其他的任务,如果我们让cpu在这段时间内切换到去做其他的任务,这样cpu不就充分利用了吗。这正是多道技术产生的技术背景

多道技术:

多道技术中的多道指的是多个程序,多道技术的实现是为了解决多个程序竞争或者说共享同一个资源(比如cpu)的有序调度问题,解决方式即多路复用,多路复用分为时间上的复用和空间上的复用。

空间上的复用:将内存分为几部分,每个部分放入一个程序,这样,同一时间内存中就有了多道程序。

时间上的复用:当一个程序在等待I/O时,另一个程序可以使用cpu,如果内存中可以同时存放足够多的作业,则cpu的利用率可以接近100%,类似于我们小学数学所学的统筹方法。(操作系统采用了多道技术后,可以控制进程的切换,或者说进程之间去争抢cpu的执行权限。这种切换不仅会在一个进程遇到io时进行,一个进程占用cpu时间过长也会切换,或者说被操作系统夺走cpu的执行权限)

空间上的复用最大的问题是:程序之间的内存必须分割,这种分割需要在硬件层面实现,由操作系统控制。如果内存彼此不分割,则一个程序可以访问另外一个程序的内存.

弊端:

​ 1.安全性差,比如你的qq程序可以访问操作系统的内存,这意味着你的qq可以拿到操作系统的所有权限。

​ 2.稳定性差,某个程序崩溃时有可能把别的程序的内存也给回收了,比方说把操作系统的内存给回收了,则操作系统崩溃。

第四代计算机(1980-至今:个人计算机

第四代也就是我们常见的操作系统,大多是具备图形化界面的,例如:Windows,macOS ,CentOS等

由于采用了IC设计,计算机的体积下降,性能增长,并且成本以及可以被普通消费者接受,而第三代操作系统大都需要进行专业的学习才能使用,于是各个大佬公司开始开发那种不需要专业学习也可以快速上手的操作系统,即上述操作系统!

它们都是用了GUI 图形化用户接口,用户只需要通过鼠标点击拖拽界面上的元素即可完成大部分操作

相关文章

  • 多进程的实现原理-多道技术

    1.操作系统 ​ 位于应用软件和硬件设备之间,本质是一个软件 核心作用: 1.为用户屏蔽了复杂繁琐的硬件接口;为应...

  • OC语法_多线程

    1. 多线程实现原理; 2. 多线程实现的方案; 3. 线程同步技术; 1. 多线程实现原理; - 进程:...

  • D神公众号学习笔记

    Docker的核心技术和实现原理: Docker核心技术支撑: Namespace:(实现了进程和网络资源的隔离)...

  • 面试题

    handler实现原理,activity启动原理,进程通信原理,多线程等等, 4、android的方向也很多,高级...

  • Android之LocalBroadCastManager实现原

    LocalBroadcastManager实现原理 1:概述 我们都知道广播可以用来实现跨进程通信,它的原理就是b...

  • Windows中半透明技术的原理及应用

    WINDOWS中半透明技术的原理及应用 摘要:探究Windows下的半透明技术的实现原理,技术细则,实现方法,其用...

  • 进程的定义、组成、组成形式和特征

    1 进程的定义 在多道程序技术之后,为了方便操作系统管理,完成各程序并发执行,引入进程。进程实体的组成:程序段、数...

  • 计算机网络:应用层

    功能原理 实现进程之间的通信。客户机进程<--->服务器进程 通过套接字socket实现发送和接受消息。可以理解为...

  • Hook技术实现Android插件化

    实现原理 通过Android的Activity启动原理可以知道startActivity()时,通过进程间通信(I...

  • ContentProvider 源码笔记

    实现原理 初始化 进程启动流程简述 客户端进程启动 -> ActivityThread#main -> Activ...

网友评论

    本文标题:多进程的实现原理-多道技术

    本文链接:https://www.haomeiwen.com/subject/oxxvlctx.html