引子

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

  进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老的也是最重要的抽象概念之一,操作系统的其他内容都是围绕着进程的概念展开的。

  所以要想真正的了解进程,必须先了解操作系统。

一,为什么要有操作系统

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

  一般而言,现代计算机系统是一个复杂的系统。

  其一:如果每位应用程序员都必须掌握该系统所有的细节,那就不可能再编写代码了
(严重影响了程序员的开发效率:全部掌握这些细节可能需要一万年....)

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

  

总结:

 程序员无法把所有的硬件操作细节都了解到,管理这些硬件并且加以优化使用是非常繁琐的工作,这个繁琐的工作就是操作系统来干的,有了他,程序员就从这些繁琐的工作中解脱了出来,只需要考虑自己的应用软件的编写就可以了,应用软件直接使用操作系统提供的功能来间接使用硬件。

二,什么是操作系统

    操作系统(Operating System,简称OS)是管理和控制计算机硬件与软件资源的计算机程序,是直接运行在“裸机”上的最基本的系统软件,任何其他软件都必须在操作系统的支持下才能运行。
    操作系统是用户和计算机的接口,同时也是计算机硬件和其他软件的接口。操作系统的功能包括管理计算机系统的硬件、软件及数据资源,控制程序运行,改善人机界面,为其它应用软件提供支持,让计算机系统所有资源最大限度地发挥作用,提供各种形式的用户界面,使用户有一个好的工作环境,为其它软件的开发提供必要的服务和相应的接口等。实际上,用户是不用接触操作系统的,操作系统管理着计算机硬件资源,同时按照应用程序的资源请求,分配资源,如:划分CPU时间,内存空间的开辟,调用打印机等。

    精简的说的话,操作系统就是一个协调、管理和控制计算机硬件资源和软件资源的控制程序。操作系统所处的位置如图1

#操作系统位于计算
机硬件与应用软件之间,本质也是一个软件。操作系统由操作系统的内核(运行于内核态,管理硬件资源)
以及系统调用(运行于用户态,为应用程序员写的应用程序提供系统调用接口)两部分组成,
所以,单纯的说操作系统是运行于内核态的,是不准确的。

 

细说的话,操作系统应该分成两部分功能:

  一:隐藏了丑陋的硬件调用接口,为应用程序员提供调用硬件资源的更好,更简单,更清晰的模型(系统调用接口)。应用程序员有了这些接口后,就不用再考虑操作硬件的细节,专心开发自己的应用程序即可。
  例如:操作系统提供了文件这个抽象概念,对文件的操作就是对磁盘的操作,有了文件我们无需再去考虑关于磁盘的读写控制(比如控制磁盘转动,移动磁头读写数据等细节),

  二:将应用程序对硬件资源的竞态请求变得有序化
  例如:很多应用软件其实是共享一套计算机硬件,比方说有可能有三个应用程序同时需要申请打印机来输出内容,那么a程序竞争到了打印机资源就打印,然后可能是b竞争到打印机资源,也可能是c,这就导致了无序,打印机可能打印一段a的内容然后又去打印c…,操作系统的一个功能就是将这种无序变得有序。

  作用一:为应用程序提供如何使用硬件资源的抽象
  例如:操作系统提供了文件这个抽象概念,对文件的操作就是对磁盘的操作,有了文件我们无需再去考虑关于磁盘的读写控制

注意:

 操作系统提供给应用程序的该抽象是简单,清晰,优雅的。为何要提供该抽象呢?

  硬件厂商需要为操作系统提供自己硬件的驱动程序(设备驱动,这也是为何我们要使
用声卡,就必须安装声卡驱动。。。),厂商为了节省成本或者兼容旧的硬件,它们的驱
动程序是复杂且丑陋的
  操作系统就是为了隐藏这些丑陋的信息,从而为用户提供更好的接口
这样用户使用的shell,Gnome,KDE看到的是不同的界面,但其实都使用了
同一套由linux系统提供的抽象接口

  
  作用二:管理硬件资源
  现代的操作系统运行同时运行多道程序,操作系统的任务是在相互竞争的程序之间有序地控制对处理器、存储器以及其他I/O接口设备的分配。
  例如:

  同一台计算机上同时运行三个程序,它们三个想在同一时刻在同一台计算机上输出
结果,那么开始的几行可能是程序1的输出,接着几行是程序2的输出,然后又是程序3
的输出,最终将是一团糟(程序之间是一种互相竞争资源的过程)

  操作系统将打印机的结果送到磁盘的缓冲区,在一个程序完全结束后,才将暂存在
磁盘上的文件送到打印机输出,同时其他的程序可以继续产生更多的输出结果(这些程
序的输出没有真正的送到打印机),这样,操作系统就将由竞争产生的无序变得有序化。

  

详解

 三,操作系统与普通软件的区别

  1.主要区别是:你不想用暴风影音了你可以选择用迅雷播放器或者干脆自己写一个,但是你无法写一个属于操作系统一部分的程序(时钟中断处理程序),操作系统由硬件保护,不能被用户修改。

  2.操作系统与用户程序的差异并不在于二者所处的地位。特别地,操作系统是一个大型、复杂、长寿的软件,

  • 大型:linux或windows的源代码有五百万行数量级。按照每页50行共1000行的书来算,五百万行要有100卷,要用一整个书架子来摆置,这还仅仅是内核部分。用户程序,如GUI,库以及基本应用软件(如windows Explorer等),很容易就能达到这个数量的10倍或者20倍之多。
  • 长寿:操作系统很难编写,如此大的代码量,一旦完成,操作系统所有者便不会轻易扔掉,再写一个。而是在原有的基础上进行改进。(基本上可以把windows95/98/Me看出一个操作系统,而windows NT/2000/XP/Vista则是两位一个操作系统,对于用户来说它们十分相似。还有UNIX以及它的变体和克隆版本也演化了多年,如System V版,Solaris以及FreeBSD等都是Unix的原始版,不过尽管linux非常依照UNIX模式而仿制,并且与UNIX高度兼容,但是linux具有全新的代码基础)

 四,操作系统发展史

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

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

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

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

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

  特点:

  1:没有操作系统的概念
  2:所有的程序设计都是直接操控硬件

  

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

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

  优点:

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

  

  缺点:

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

  

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

 

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

 

  由于当时的计算机非常昂贵,自认很自然的想办法较少机时的浪费。通常采用的方法就是批处理系统。

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

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

 

工作过程:插图

 

 

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

  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)的有序调度问题,解决方式即多路复用,多路复用分为时间上的复用和空间上的复用。

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

 

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

  现代计算机或者网络都是多用户的,多个用户不仅共享硬件,而且共享文件,数据库等信息,共享意味着冲突和无序。

  操作系统主要使用来干什么?

  1.记录哪个程序使用什么资源
  2.对资源请求进行分配
  3.为不同的程序和用户调解互相冲突的资源请求。

  

  我们可将上述操作系统的功能总结为:处理来自多个程序发起的多个(多个即多路)共享(共享即复用)资源的请求,简称多路复用

多路复用有两种实现方式

  1.时间上的复用

  当一个资源在时间上复用时,不同的程序或用户轮流使用它,第一个程序获取
该资源使用结束后,在轮到第二个。。。第三个。。。

  例如:只有一个cpu,多个程序需要在该cpu上运行,操作系统先把cpu分给第
一个程序,在这个程序运行的足够长的时间(时间长短由操作系统的算法说了算)
或者遇到了I/O阻塞,操作系统则把cpu分配给下一个程序,以此类推,直到第一个
程序重新被分配到了cpu然后再次运行,由于cpu的切换速度很快,给用户的感觉就
是这些程序是同时运行的,或者说是并发的,或者说是伪并行的。至于资源如何实现
时间复用,或者说谁应该是下一个要运行的程序,以及一个任务需要运行多长时间,
这些都是操作系统的工作。

  

  2.空间上的复用

  每个客户都获取了一个大的资源中的一小部分资源,从而减少了排队等待资源的时间。
  例如:多个运行的程序同时进入内存,硬件层面提供保护机制来确保各自的内存是分
割开的,且由操作系统控制,这比一个程序独占内存一个一个排队进入内存效率要高的多。

  

  有关空间复用的其他资源还有磁盘,在许多系统中,一个磁盘同时为许多用户保存文件。分配磁盘空间并且记录谁正在使用哪个磁盘块是操作系统资源管理的典型任务。这两种方式合起来便是多道技术详解

  空间上的复用最大的问题是:

  程序之间的内存必须分割,这种分割需要在硬件层面实现,由操作系统控制。如果内存彼
此不分割,则一个程序可以访问另外一个程序的内存,
  首先丧失的是安全性,比如你的qq程序可以访问操作系统的内存,这意味着你的qq可以拿
到操作系统的所有权限。
  其次丧失的是稳定性,某个程序崩溃时有可能把别的程序的内存也给回收了,比方说把操作
系统的内存给回收了,则操作系统崩溃。

  

  第三代计算机的操作系统仍然是批处理

  许多程序员怀念第一代独享的计算机,可以即时调试自己的程序。为了满足程序员们很快可以得
到响应,出现了分时操作系统

  

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

  分时操作系统:
  多个联机终端+多道技术
  20个客户端同时加载到内存,有17在思考,3个在运行,cpu就采用多道的方式处理内存
中的这3个程序,由于客户提交的一般都是简短的指令而且很少有耗时长的,索引计算机能够
为许多用户提供快速的交互式服务,所有的用户都以为自己独享了计算机资源
  CTTS:麻省理工(MIT)在一台改装过的7094机上开发成功的,CTSS兼容分时系统,
第三代计算机广泛采用了必须的保护硬件(程序之间的内存彼此隔离)之后,分时系统才开始流行
MIT,贝尔实验室和通用电气在CTTS成功研制后决定开发能够同时支持上百终端的MULTICS
(其设计者着眼于建造满足波士顿地区所有用户计算需求的一台机器),很明显真是要上天啊,
最后摔死了。
  后来一位参加过MULTICS研制的贝尔实验室计算机科学家Ken Thompson开发了一个简
易的,单用户版本的MULTICS,这就是后来的UNIX系统。基于它衍生了很多其他的Unix版本,
为了使程序能在任何版本的unix上运行,IEEE提出了一个unix标准,即posix(可移植的操作
系统接口Portable Operating System Interface)
  后来,在1987年,出现了一个UNIX的小型克隆,即minix,用于教学使用。芬兰学
生Linus Torvalds基于它编写了Linux

  

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

    大型机与嵌入式系统使用很多样化的操作系统。在服务器方面Linux、UNIX和WindowsServer占据了市场的大部分份额。在超级计算机方面,Linux取代Unix成为了第一大操作系统,截止2012年6月,世界超级计算机500强排名中基于Linux的超级计算机占据了462个席位,比率高达92%。随着智能手机的发展,Android和iOS已经成为目前最流行的两大手机操作系统。
    2012年,全球智能手机操作系统市场份额的变化情况相对稳定。智能手机操作系统市场一直被几个手机制造商巨头所控制,而安卓的垄断地位主要得益于三星智能手机在世界范围内所取得的巨大成功。2012年第三季度,安卓的市场份额高达74.8%,2011年则为57.4%。2013年第一季度,它的市场份额继续增加,达到75%。虽然 Android 占据领先,但是苹果 iOS 用户在应用上花费的时间则比 Android 的长。虽然在这方面 Android 的数字一度接近苹果,但是像 iPad 3 这样的设备发布之后,苹果的数字还是会进一步增长。Windows Phone 系统在 8.1 版发布后市场份额稳步提高,应用生态正在改善,众多必需应用不断更新,但是速度还略嫌迟缓。微软收购了诺基亚,发展了许多OEM厂商,并不断发布新机型试图扭转WP的不利局面,小有成效。

 五,操作系统的目的

  操作系统的目标:方便性,有效性,可扩充性,开放性

  操作系统是配置在计算机硬件上的第一层软件,是对硬件系统的首次扩充,它的主要作用是管理好这些设备,提高它们的利用率和系统的吞吐率,并为用户和应用程序提供一个简单的接口,便于用户使用,也可以理解为操作系统是一个应用软件运行的平台,也是用户使用应用软件的一个工具。

  也可以说是 合理地组织计算机的工作流程,直接控制和管理计算机硬件和软件资源

  1.方便性

  如果在计算机硬件上配置了OS,系统便可以使用编译命令将用户采用高级语言编写的程序翻译成机器代码,或者直接通过OS所提供的各种命令操作计算机系统,这样就极大地方便了用户,其中计算机系统包括硬件和软件。

  2.有效性

  第一是提高系统资源的利用率,避免处理机,I/O设备经常处于空闲状态,各种资源无法得到充分的利用,第二是提高系统的吞吐率,OS可以通过合理地组织计算机的工作流程,加速程序的运行,缩短程序的运行周期,从而提高系统的吞吐量。

  系统的吞吐量可以理解为系统运行的程序的数量。

  3.可扩充性

  可以在原来的基础上很容易地修改,增加功能,以适应计算机硬件,体系结构,计算机应用发展的要求。而今年来使用的微内核结构能方便地添加新的功能和模块,以及对原有的功能和模块进行修改,具有良好的可扩充性。

  4.开放性

  开放性也可以说是兼容性,软硬件要具有良好的兼容性,即要遵循一个具体的标准。

  所谓开放性,是指系统能遵循世界标准规范,特别是遵循开放系统互联OSI国际标准。

 

六,典型的操作系统

——UNIX

  UNIX 是一个强大的多用户、多任务操作系统,支持多种处理器架构,按照操作系统的分类,属于分时操作系统。UNIX 最早由Ken Thompson和Dennis Ritchie于1969年在美国AT&T的贝尔实验室开发。
  类Unix(Unix-like)操作系统指各种传统的Unix以及各种与传统Unix类似的系统。它们虽然有的是自由软件,有的是商业软件,但都相当程度地继承了原始UNIX的特性,有许多相似处,并且都在一定程度上遵守POSIX规范。类Unix系统可在非常多的处理器架构下运行,在服务器系统上有很高的使用率,例如大专院校或工程应用的工作站。

——Linux

  基于Linux的操作系统是20世纪1991年推出的一个多用户、多任务的操作系统。它与UNIX完全兼容。Linux最初是由芬兰赫尔辛基大学计算机系学生Linus Torvalds在基于UNIX的基础上开发的一个操作系统的内核程序,Linux的设计是为了在Intel微处理器上更有效的运用。其后在理查德·斯托曼的建议下以GNU通用公共许可证发布,成为自由软件Unix变种。它的最大的特点在于他是一个源代码公开的自由及开放源码的操作系统,其内核源代码可以自由传播。
经历数年的披荆斩棘,自由开源的Linux系统逐渐蚕食以往专利软件的专业领域,例如以往计算机动画运算巨擘──SGI的IRIX系统已被Linux家族及贝尔实验室研发小组设计的九号计划与Inferno系统取代,皆用于分散表达式环境。它们并不像其他Unix系统,而是选择自带图形用户界面。九号计划原先并不普及,因为它刚推出时并非自由软件。Linux有各类发行版,通常为GNU/Linux,如Debian(及其衍生系统Ubuntu、Linux Mint)、Fedora、openSUSE等。Linux发行版作为个人计算机操作系统或服务器操作系统,在服务器上已成为主流的操作系统。

——Mac OS X

  Mac OS是一套运行于苹果Macintosh系列电脑上的操作系统。Mac OS是首个在商用领域成功的图形用户界面。Macintosh组包括比尔·阿特金森(Bill Atkinson)、杰夫·拉斯金(Jef Raskin)和安迪·赫茨菲尔德(Andy Hertzfeld)。Mac OS X 于 2001年 首次在商场上推出。它包含两个主要的部分:Darwin,是以 BSD 原始代码和 Mach 微核心 为基础,类似 Unix 的开放原始码环境。

——Windows

  Windows是由微软公司成功开发的操作系统.Windows是一个多任务的操作系统,他采用图形窗口界面,用户对计算机的各种复杂操作只需通过点击鼠标就可以实现。

  Microsoft Windows系列操作系统是在微软给IBM机器设计的MS-DOS的基础上设计的图形操作系统。Windows系统,如Windows 2000、Windows XP皆是创建于现代的Windows NT内核。NT内核是由OS/2和OpenVMS等系统上借用来的。Windows可以在32位和64位的Intel和AMD的处理器上运行,但是早期的版Windows 8 Metro 本也可以在DEC Alpha、MIPS与PowerPC架构上运行。 虽然由于人们对于开放源代码作业系统兴趣的提升,Windows的市场占有率有所下降,但是到2004年据库服务等一些功能。
  Windows XP在2001年10月25日发布,2004年8月24日发布服务包2,2008年4月21日发布最新的服务包3。 微软上一款操作系统Windows Vista(开发代码为Longhorn)于2007年1月30日发售[4]。Windows Vista增加了许多功能,尤其是系统的安全性和网络管理功能,并且其拥有界面华丽的Aero Glass。但是整体而言,其在全球市场上的口碑却并不是很好。Windows 8微软在2012年10月正式推出,系统有着独特的metro开始界面和触控式交互系统,2013年10月17日晚上7点,Windows 8.1在全球范围内,通过Windows上的应用商店进行更新推送。2014年1月22日,微软在美国旧金山举行发布会,正式发布了Windows 10消费者预览版。

——iOS

  iOS操作系统是由苹果公司开发的手持设备操作系统。iOS与苹果的Mac OS X操作系统一样,它也是以Darwin为基础的,因此同样属于类Unix的商业操作系统。原本这个系统名为iPhone OS,直到2010年6月7日WWDC大会上宣布改名为iOS。截止至2011年11月,根据Canalys的数据显示,iOS已经占据了全球智能手机系统市场份额的30%,在美国的市场占有率为43%  

——Android

  Android是一种以Linux为基础的开放源代码操作系统,主要使用于便携设备。[8]  Android操作系统最初由Andy Rubin开发,最初主要支持手机。2005年由Google收购注资,并组建开放手机联盟开发改良,逐渐扩展到平板电脑及其他领域上。2011年第一季度,Android在全球的市场份额首次超过塞班系统,跃居全球第一。 2012年11月数据显示,Android占据全球智能手机操作系统市场76%的份额,中国市场占有率为90%。[

——WP

  Windows Phone(简称:WP)是微软发布的一款手机操作系统,它将微软旗下的Xbox Live游戏、Xbox Music音乐与独特的视频体验集成至手机中。微软公司于2010年10月11日晚上9点30分正式发布了智能手机操作系统Windows Phone,并将其使用接口称为“Modern”接口。2011年2月,“诺基亚”与微软达成全球战略同盟并深度合作共同研发。2011年9月27日,微软发布Windows Phone 7.5。2012年6月21日,微软正式发布Windows Phone 8,采用和Windows 8相同的Windows NT内核,同时也针对市场的Windows Phone 7.5发布Windows Phone 7.8。2014年4月2日,微软在旧金山召开Build2014开发者大会。大会上微软推出Windows Phone 8.1更新,2014年8月4日晚,微软正式向WP开发者推送了WP8.1 GDR1预览版,即WP8.1 Update。

——Chrome OS

  Chrome OS是由谷歌开发的一款基于Linux的操作系统,发展出与互联网紧密结合的云操作系统,工作时运行Web应用程序。谷歌在2009年7月7日发布该操作系统,并在2009年11月19日以Chromium OS之名推出相应的开源项目,并将Chromium OS代码开源。

   Chrome OS同时支持Intel x86以及ARM处理器,软件结构极其简单,可以理解为在Linux的内核上运行一个使用新的窗口系统的Chrome浏览器。对于开发人员来说,web就是平台,所有现有的web应用可以完美的在Chrome OS中运行,开发者也可以用不同的开发语言为其开发新的web应用。
 

七,总结

  即使可以利用的cpu只有一个(早期的计算器确实如此),也能保证支持(伪)并发功能,将一个单独的cpu变成多个虚拟的cpu(多道技术:时间多路复用和空间多路复用+硬件上支持隔离),没有进程的抽象,现代计算机将不复存在。

一 操作系统的作用:
    1:隐藏丑陋复杂的硬件接口,提供良好的抽象接口
    2:管理、调度进程,并且将多个进程对硬件的竞争变得有序

二 多道技术:
    1.产生背景:针对单核,实现并发
    ps:
    现在的主机一般是多核,那么每个核都会利用多道技术
    有4个cpu,运行于cpu1的某个程序遇到io阻塞,会等到io结束再重新调度,会被调度到4个
    cpu中的任意一个,具体由操作系统调度算法决定。

    2.空间上的复用:如内存中同时有多道程序
    3.时间上的复用:复用一个cpu的时间片
       强调:遇到io切,占用cpu时间过长也切,核心在于切之前将进程的状态保存下来,这样
            才能保证下次切换回来时,能基于上次切走的位置继续运行

  

 

 参考内容:https://www.cnblogs.com/linhaifeng/p/6295875.html;百度百科;写在此处的目的是巩固老师所讲知识,课后为了方便复习

版权声明:本文为wj-1314原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/wj-1314/p/8302269.html