进程的引入,计算机的发展史

并发的背景

引入:

顾名思义,进程即正在执行的一个过程。进程是对正在运行程序的一个抽象。编程

操做系统的发展

为何要有操做系统

现代的计算机系统主要是由一个或者多个处理器,主存,硬盘,键盘,鼠标,显示器,打印机,网络接口及其余输入输出设备组成。服务器

通常而言,现代计算机系统是一个复杂的系统。网络

其一:若是每位应用程序员都必须掌握该系统全部的细节,那就不可能再编写代码了(严重影响了程序员的开发效率)并发

其二:而且管理这些部件并加以优化使用,是一件极富挑战性的工做,因而,计算安装了一层软件(系统软件),称为操做系统。它的任务就是为用户程序提供一个更好、更简单、更清晰的计算机模型,并管理刚才提到的全部设备。性能

总结:优化

程序员没法把全部的硬件操做细节都了解到,管理这些硬件而且加以优化使用是很是繁琐的工做,这个繁琐的工做就是操做系统来干的,有了他,程序员就从这些繁琐的工做中解脱了出来,只须要考虑本身的应用软件的编写就能够了,应用软件直接使用操做系统提供的功能来间接使用硬件。操作系统

发展史

第一代计算机(1940~1955):真空管和插件板

第一代计算机的产生背景:插件

第一代以前人类是想用机械取代人力,第一代计算机的产生是计算机由机械时代进入电子时代的标志,从Babbage失败以后一直到第二次世界大战,数字计算机的建造几乎没有什么进展,第二次世界大战刺激了有关计算机研究的爆炸性进展。设计

lowa州立大学的john Atanasoff教授和他的学生Clifford Berry建造了据认为是第一台可工做的数字计算机。该机器使用300个真空管。大约在同时,Konrad Zuse在柏林用继电器构建了Z3计算机,英格兰布莱切利园的一个小组在1944年构建了Colossus,Howard Aiken在哈佛大学建造了Mark 1,宾夕法尼亚大学的William Mauchley和他的学生J.Presper Eckert建造了ENIAC。这些机器有的是二进制的,有的使用真空管,有的是可编程的,但都很是原始,设置须要花费数秒钟时间才能完成最简单的运算。

在这个时期,同一个小组里的工程师们,设计、建造、编程、操做及维护同一台机器,全部的程序设计是用纯粹的机器语言编写的,甚至更糟糕,须要经过成千上万根电缆接到插件板上连成电路来控制机器的基本功能。没有程序设计语言(汇编也没有),操做系统则是历来都没据说过。使用机器的过程更加原始,详见下‘工做过程’。

特色:

没有操做系统的概念
全部的程序设计都是直接操控硬件

工做过程:

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

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

优势:

程序员在申请的时间段内独享整个资源,能够即时地调试本身的程序(有bug能够马上处理)

缺点:

浪费计算机资源,一个时间段内只有一我的用。
注意:同一时刻只有一个程序在内存中,被cpu调用执行,比方说10个程序的执行,是串行的

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

第二代计算机的产生背景:

因为当时的计算机很是昂贵,自认很天然的想办法较少机时的浪费。一般采用的方法就是批处理系统。

特色:
设计人员、生产人员、操做人员、程序人员和维护人员直接有了明确的分工,计算机被锁在专用空调房间中,由专业操做人员运行,这即是‘大型机’。

有了操做系统的概念

有了程序设计语言:FORTRAN语言或汇编语言,写到纸上,而后穿孔打成卡片,再讲卡片盒带到输入室,交给操做员,而后喝着咖啡等待输出接口

工做过程:插图

img

img

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

1.把一堆人的输入攒成一大波输入,
2.而后顺序计算(这是有问题的,可是第二代计算也没有解决)
3.把一堆人的输出攒成一大波输出

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

优势:

批处理,节省了机时

缺点:

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

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

3.程序员原来独享一段时间的计算机,如今必须被统一规划到一批做业中,等待结果和从新调试的过程都须要等同批次的其余程序都运做完才能够(这极大的影响了程序的开发效率,没法及时调试程序)

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

第三代计算机的产生背景:

20世纪60年代初期,大多数计算机厂商都有两条彻底不兼容的生产线。

一条是面向字的:大型的科学计算机,如IBM 7094,见上图,主要用于科学计算和工程计算

另一条是面向字符的:商用计算机,如IBM 1401,见上图,主要用于银行和保险公司从事磁带归档和打印服务

开发和维护彻底不一样的产品是昂贵的,同时不一样的用户对计算机的用途不一样。

IBM公司试图经过引入system/360系列来同时知足科学计算和商业计算,360系列低档机与1401至关,高档机比7094功能强不少,不一样的性能卖不一样的价格

360是第一个采用了(小规模)芯片(集成电路)的主流机型,与采用晶体管的第二代计算机相比,性价比有了很大的提升。这些计算机的后代仍在大型的计算机中内心使用,此乃如今服务器的前身,这些服务器每秒处理不小于千次的请求。

如何解决第二代计算机的问题1:

卡片被拿到机房后可以很快的将做业从卡片读入磁盘,因而任什么时候刻当一个做业结束时,操做系统就能将一个做业从磁带读出,装进空出来的内存区域运行,这种技术叫作
同时的外部设备联机操做:SPOOLING,该技术同时用于输出。当采用了这种技术后,就不在须要IBM1401机了,也没必要将磁带搬来搬去了(中间俩小人再也不须要)

如何解决第二代计算机的问题2:

第三代计算机的操做系统普遍应用了第二代计算机的操做系统没有的关键技术:多道技术

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

多道技术:

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

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

img

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

相关文章
相关标签/搜索