首页 > 编程语言 >并发编程

并发编程

时间:2024-01-17 20:23:07浏览次数:34  
标签:操作系统 编程 程序 复用 并发 内存 cpu 计算机

操作系统

(一)引入

  • 顾名思义,进程即正在执行的一个过程。
    • 进程是对正在运行程序的一个抽象。
  • 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一。
    • 操作系统的其他所有内容都是围绕进程的概念展开的。
  • 所以想要真正了解进程,必须事先了解操作系统

(二)为什么要有操作系统

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

(1)开发效率变慢

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

(2)优化操作行为

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

(3)总结

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

(三)什么是操作系统

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

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

img

(1)操作系统的功能

(1)隐藏硬件调用接口

  • 隐藏了丑陋的硬件调用接口,为应用程序员提供调用硬件资源的更好,更简单,更清晰的模型(系统调用接口)。

  • 应用程序员有了这些接口后,就不用再考虑操作硬件的细节,专心开发自己的应用程序即可。

    例如:操作系统提供了文件这个抽象概念,对文件的操作就是对磁盘的操作,有了文件我们无需再去考虑关于磁盘的读写控制(比如控制磁盘转动,移动磁头读写数据等细节)
    

(2)资源有序化

  • 将应用程序对硬件资源的竞态请求变得有序化

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

(2)操作系统的功能详解

  • 现代计算机或者网络都是多用户的,多个用户不仅共享硬件,而且共享文件,数据库等信息,共享意味着冲突和无序。
  • 操作系统主要是用来
    • 记录哪个程序使用什么资源
    • 对资源请求进行分配
    • 为不同的程序和用户调解互相冲突的资源请求。
  • 我们可将上述操作系统的功能总结为:
    • 处理来自多个程序发起的多个(多个即多路)共享(共享即复用)资源的请求,简称多路复用

(3)多路复用的两种实现方式

(1)时间上的复用

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

(2)空间上的复用

  • 每个客户都获取了一个大的资源中的一小部分资源,从而减少了排队等待资源的时间。
  • 例如:
    • 多个运行的程序同时进入内存,硬件层面提供保护机制来确保各自的内存是分割开的,且由操作系统控制,这比一个程序独占内存一个一个排队进入内存效率要高的多。
  • 有关空间复用的其他资源还有磁盘,在许多系统中,一个磁盘同时为许多用户保存文件。
    • 分配磁盘空间并且记录谁正在使用哪个磁盘块是操作系统资源管理的典型任务。

(3)多道技术

  • 这两种方式合起来便是多道技术

img

(四)操作系统与普通软件的区别

  • 主要区别是:

    • 你不想用暴风影音了你可以选择用迅雷播放器或者干脆自己写一个
    • 但是你无法写一个属于操作系统一部分的程序(时钟中断处理程序)
    • 操作系统由硬件保护,不能被用户修改。
  • 操作系统与用户程序的差异并不在于二者所处的地位。

    • 特别地,操作系统是一个大型、复杂、长寿的软件。

(五)操作系统的发展史

(1)第一代计算机(1940~1955):真空管和穿孔卡片

(1)产生背景

  • 第一代之前人类是想用机械取代人力
  • 第一代计算机的产生是计算机由机械时代进入电子时代的标志
  • 从Babbage失败之后一直到第二次世界大战,数字计算机的建造几乎没有什么进展
  • 第二次世界大战刺激了有关计算机研究的爆炸性进展。
lowa州立大学的john Atanasoff教授和他的学生Clifford Berry建造了据认为是第一台可工作的数字计算机。

该机器使用300个真空管。大约在同时,Konrad Zuse在柏林用继电器构建了Z3计算机,英格兰布莱切利园的一个小组在1944年构建了Colossus,Howard Aiken在哈佛大学建造了Mark 1,宾夕法尼亚大学的William Mauchley和他的学生J.Presper Eckert建造了ENIAC。

这些机器有的是二进制的,有的使用真空管,有的是可编程的,但都非常原始,设置需要花费数秒钟时间才能完成最简单的运算。

(2)技术背景

  • 同一个小组里的工程师们,设计、建造、编程、操作及维护同一台机器

  • 所有的程序设计是用纯粹的机器语言编写的,甚至更糟糕

  • 需要通过成千上万根电缆接到插件板上连成电路来控制机器的基本功能。

  • 没有程序设计语言(汇编也没有),操作系统则是从来都没听说过。

  • 使用机器的过程更加原始,详见下‘工作过程’

(3)特点

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

(4)工作过程

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

(5)优点

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

(6)缺点

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

    注意:同一时刻只有一个程序在内存中,被cpu调用执行,比方说10个程序的执行,是串行的

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

(1)产生背景

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

(2)特点

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

(3)技术背景

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

img

(4)第二代如何解决第一代的问题/缺点

  • 把一堆人的输入攒成一大波输入,
  • 然后顺序计算(这是有问题的,但是第二代计算也没有解决)
  • 把一堆人的输出攒成一大波输出

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

(1)产生背景

  • 20世纪60年代初期,大多数计算机厂商都有两条完全不兼容的生产线。
    • 一条是面向字的:
      • 大型的科学计算机
      • 如IBM 7094,见上图,主要用于科学计算和工程计算
    • 另外一条是面向字符的:
      • 商用计算机,如IBM 1401,见上图
      • 主要用于银行和保险公司从事磁带归档和打印服务
  • 开发和维护完全不同的产品是昂贵的
    • 同时不同的用户对计算机的用途不同。

(2)技术背景

  • IBM公司试图通过引入system/360系列来同时满足科学计算和商业计算
    • 360系列低档机与1401相当,高档机比7094功能强很多
    • 不同的性能卖不同的价格
  • 360是第一个采用了(小规模)芯片(集成电路)的主流机型
    • 与采用晶体管的第二代计算机相比,性价比有了很大的提高。
    • 这些计算机的后代仍在大型的计算机中心里使用,此乃现在服务器的前身
    • 这些服务器每秒处理不小于千次的请求。

(3)如何解决第二代计算机的问题1

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

(4)如何解决第二代计算机的问题2

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

(5)多道技术

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

[1]空间上的复用

  • 将内存分为几部分,每个部分放入一个程序,这样,同一时间内存中就有了多道程序。

[2]时间上的复用

  • 当一个程序在等待I/O时,另一个程序可以使用cpu

  • 如果内存中可以同时存放足够多的作业,则cpu的利用率可以接近100%

  • 类似于我们小学数学所学的统筹方法

    (操作系统采用了多道技术后,可以控制进程的切换
    
    或者说进程之间去争抢cpu的执行权限。
    
    这种切换不仅会在一个进程遇到io时进行,一个进程占用cpu时间过长也会切换
    
    或者说被操作系统夺走cpu的执行权限)
    

[3]详解:

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

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

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

(6)如何解决第二代计算机的问题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

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

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

(5)发展史概览

计算机发展阶段 时间 组成 改进 缺陷
第一代计算机 1940~1955 真空管和穿孔卡片 没有操作系统的概念 所有的程序设计都是直接操控硬件
第二代计算机 1955~1965 晶体管和批处理系统 批处理,节省机时 全程需要人参与,仍是串行,无法及时调试程序
第三代计算机 1965~1980 集成电路芯片和多道程序设计 运用多道技术
第四代计算机 1980至今 个人计算机 支持(伪)并发的能力

【六】总结

(1)操作系统的作用

  • 隐藏丑陋复杂的硬件接口,提供良好的抽象接口
  • 管理、调度进程,并且将多个进程对硬件的竞争变得有序

(2)多道技术

(1)产生背景:针对单核,实现并发

  • 现在的主机一般是多核,那么每个核都会利用多道技术 有4个cpu,运行于cpu1的某个程序遇到io阻塞,会等到io结束再重新调度,会被调度到4个cpu中的任意一个,具体由操作系统调度算法决定。

(2)空间上的复用:如内存中同时有多道程序

  • 空间上的复用指的是在内存中同时运行多个程序,这样可以有效地利用内存资源。

(3)时间上的复用:复用一个cpu的时间片

  • 指共享同一台机器的多个进程可以轮流使用CPU,从而避免了长时间等待的情况发生。
  • 强调:遇到io切,占用cpu时间过长也切,核心在于切之前将进程的状态保存下来,这样才能保证下次切换回来时,能基于上次切走的位置继续运行

(3)操作系统发展史

  • 第一代计算机1940-1955:真空管和穿孔卡片
  • 第二代计算机1955-1965:晶体管和批处理系统
  • 第三代计算机1965-1980:集成电路芯片和多道程序设计
  • 第四代计算机1980-至今:个人计算机

标签:操作系统,编程,程序,复用,并发,内存,cpu,计算机
From: https://www.cnblogs.com/suyihang/p/17971085

相关文章

  • Java异步编程详解
    在现代应用程序开发中,异步编程变得越来越重要,特别是在处理I/O密集型任务时。Java提供了一套强大的异步编程工具,使得开发者能够更有效地处理并发任务。本篇博文将深入探讨Java中异步编程的方方面面,通过具体例子详细说明异步编程的实践。异步编程的背景在传统的同步编程模型中,任务......
  • 模板编程
    函数模板不是一个实在的函数,编译器不能为其生成可执行代码。定义函数模板后只是一个对函数功能框架的描述,当他具体执行的时候,将根据传递的实际参数决定其功能(运行期间的多态,动态多态)。C++提供两种模板机制:类模板和函数模板。注意这里T类型必须在使用模板的时候定义,而且可以有多个T......
  • ASP.NET Core 中AOP(面向切面编程)的支持方式
    在ASP.NETCore中,AOP(面向切面编程)的支持可以通过以下方式实现:过滤器(Filters):ASP.NETCore提供了多种类型的过滤器:身份验证过滤器(AuthenticationFilters):用于验证用户身份。例如,[Authorize] 属性可以应用在控制器或动作方法上,确保只有经过身份验证的用户才能访问。授权......
  • 使用 Python 创造你自己的计算机游戏(游戏编程快速上手)第四版:第十五章到第十八章
    十五、反转棋游戏原文:inventwithpython.com/invent4thed/chapter15.html译者:飞龙协议:CCBY-NC-SA4.0在本章中,我们将制作反转棋,也称为黑白棋或奥赛罗。这个双人棋盘游戏是在网格上进行的,因此我们将使用带有x和y坐标的笛卡尔坐标系。我们的游戏版本将具有比第10章中的......
  • 使用 Python 创造你自己的计算机游戏(游戏编程快速上手)第四版:第十九章到第二十一章
    十九、碰撞检测原文:inventwithpython.com/invent4thed/chapter19.html译者:飞龙协议:CCBY-NC-SA4.0碰撞检测涉及确定屏幕上的两个物体何时相互接触(即发生碰撞)。碰撞检测对于游戏非常有用。例如,如果玩家触碰到敌人,他们可能会失去生命值。或者如果玩家触碰到硬币,他们应该自动......
  • 使用 Python 创造你自己的计算机游戏(游戏编程快速上手)第四版:第五章到第九章
    五、龙之境原文:inventwithpython.com/invent4thed/chapter5.html译者:飞龙协议:CCBY-NC-SA4.0本章中您将创建的游戏名为龙之境。玩家需要在两个洞穴之间做出选择,这两个洞穴分别藏有宝藏和一定的厄运。如何玩龙之境在这个游戏中,玩家身处一个充满龙的土地。这些龙都住在洞......
  • 模型组成的编程世界
    现实世界中的树,它被人起名叫做树,就是人给这种特征的集合做了一个模型,并给其命名为树。编程的世界中也有很多的专有名词,这就是程序员先辈们给模型命的名。吸收二氧化碳,阳光催化,生根于土地————>树各种特征的集合————>模型模型的存在一定程度上减少了记忆的复杂程度......
  • 使用 Python 创造你自己的计算机游戏(游戏编程快速上手)第四版:第十章到第十四章
    十、井字棋原文:inventwithpython.com/invent4thed/chapter10.html译者:飞龙协议:CCBY-NC-SA4.0本章介绍了一个井字棋游戏。井字棋通常由两个人玩。一个玩家是X,另一个玩家是O。玩家轮流放置他们的X或O。如果一个玩家在一行、一列或对角线上获得了三个标记,他们就赢了。当棋盘......
  • 使用 Python 创造你自己的计算机游戏(游戏编程快速上手)第四版:致谢到第四章
    致谢原文:inventwithpython.com/invent4thed/chapter0.html译者:飞龙协议:CCBY-NC-SA4.0没有NoStarchPress团队的出色工作,这本书就不可能问世。感谢我的出版商BillPollock;感谢我的编辑LaurelChun、JanCash和TylerOrtman,在整个过程中给予我的难以置信的帮助;感谢我......
  • OpenMP学习 第四章 线程与OpenMP编程模型
    第四章线程与OpenMP编程模型编译器指令为了将顺序程序转换为并行程序,修改代码的最小干扰方式是通过编译器指令.在C/C++中,指令通过编译器表示#pragmaompparallel[clause[[,]clause]...]#pragmaompparallelprivate(x){//codeexecutedbyeachthread}大部分......