当前位置: 首页 > article >正文

[操作系统] 深入理解约翰·冯·诺伊曼体系

约翰·冯诺依曼(John von Neumann,1903年12月28日—1957年2月8日),原名诺伊曼·亚诺什·拉约什(Neumann János Lajos),出生于匈牙利的美国籍犹太人数学家,20世纪最重要的数学家之一,在现代计算机、博弈论、核武器和生化武器等领域内的科学全才之一,被后人称为“计算机之父”和“博弈论之父”。设计了世界上第一台通用计算机:电子数字积分计算机(The Electronic Numerical Integrator and Computer)——简称“埃尼阿克”。受“图灵机”的影响提出冯诺依曼体系结构。

冯诺依曼体系(Von Neumann Architecture)是现代计算机设计的基石。无论是笔记本电脑、手机还是服务器,大多数计算机都遵循这一体系结构。本文将从冯诺依曼体系的基本概念出发,结合实际案例,深入剖析它在实际数据流中的应用。


什么是冯诺依曼体系?

冯诺依曼体系的核心思想是将存储器作为中央组件,所有数据的输入、输出、处理都围绕存储器进行。本质就是将数据进行拷贝,从一个节点拷贝到另一个节点然后进行处理,而拷贝的输入输出设备之间的拷贝效率会影响这个计算机的运行效率,所以说实际上计算机的性能就是各个节点之间的输入输出效率。而IO(input,output)需要站在内存(存储器)的角度进行理解,下文会做出解答。

冯诺依曼体系组成部分

  • 输入单元(输入设备):如键盘、鼠标、触摸屏等,将数据传入存储器。
  • 中央处理器(CPU):包括运算器控制器,用于从内存中读取数据和指令并执行。
  • 存储单元(存储器):即内存,用于存储当前正在处理的数据和指令。
  • 输出单元(输出设备):如显示器、打印机等,用于从存储器中读取数据并展示或输出。

内存是中心枢纽

在冯诺依曼体系中,内存是整个计算机体系结构的核心组件,所有计算和数据交互都以内存为中心:

  • CPU只能直接访问内存:冯诺依曼体系的一个基本原则是,CPU只能对内存进行读写,无法直接访问输入输出设备。这使得内存成为数据处理的中转站。
  • 输入设备和输出设备无法直接通信:所有输入数据(例如键盘输入)必须先写入内存,然后由CPU读取并处理;同样,所有输出数据(例如屏幕显示)也必须先写入内存,再由输出设备读取。
为什么内存是中心?
  1. 统一管理:通过内存,所有设备都可以遵循统一的读写规则,不需要设备之间直接交互的复杂逻辑。
  2. 存储指令与数据:内存既存储程序指令,也存储需要处理的数据。CPU可以从内存中同时读取指令和数据进行操作,这种统一的存储模型极大简化了硬件设计。

CPU与内存的关系

CPU只能直接访问内存,无法直接与外设通信。执行指令时,CPU需要从内存中取出指令(Fetch)、解码(Decode)、执行(Execute),这就是所谓的指令周期。

外设与内存的关系

外设(输入和输出设备)不能直接与CPU通信,只能通过内存中转。比如,键盘输入的数据会先存储到内存中,CPU随后读取内存处理这些数据。


为什么不直接CPU相通输入输出设备?

硬盘、内存和CPU的IO效率如下图类比所示,逐个递增。

我们在使用计算机的时候,软件存放于磁盘中,当我们要使用该软件的时候软件就会加载到内存中,然后再与CPU交互,得到的信息通过输出设备(显示屏)刷新显示信息。既然CPU效率更高,我们为什么不直接将输入输出设备与CPU相通呢?

直接让CPU与输入输出设备(I/O设备)通信在理论上是可行的,但实际上会引发诸多问题,从设计复杂性、性能效率到可扩展性等方面都会遇到重大挑战。以下是为什么在冯诺依曼体系中,CPU不能直接与输入输出设备通信,而是通过内存中转的核心原因:

设备种类多样性,接口复杂化

现代计算机中有大量不同种类的I/O设备,例如键盘、鼠标、显示器、硬盘、打印机、网络适配器等,这些设备具有各自的通信协议、数据格式和操作方式:

  • 通信协议差异:每种设备的通信方式(串行、并行等)和速率差别很大。
  • 数据格式差异:设备处理的数据类型不同(键盘是按键事件,硬盘是块数据,网络是分组数据)。
  • 如果CPU需要直接与每种设备通信,CPU必须内置支持所有这些协议和格式的逻辑。这不仅会大幅增加CPU的复杂性,还会导致硬件接口的维护和升级困难。

解决方案:通过内存间接通信

  • 引入内存后,设备之间通过统一的数据格式存储到内存中,CPU只需要按照内存中的数据结构处理即可,无需关心设备本身的差异。
  • 外设驱动程序(由操作系统提供)负责将不同设备的数据格式转换为CPU可以理解的格式。

速度差异:CPU和I/O设备工作速度不匹配

CPU的速度远远高于大多数I/O设备,例如:

  • CPU的指令执行速度可以达到每秒数十亿次,而硬盘读写速度可能只有数百MB/s,打印机的输出速度甚至更慢。
  • 如果CPU直接等待设备完成数据传输,CPU大部分时间将被闲置,浪费了巨大的性能。

这就是木桶效应。

解决方案:通过内存和缓冲机制解耦

  • 输入设备可以将数据缓存在内存中,CPU按需读取并处理,而不需要实时等待设备完成操作。
  • 输出设备可以从内存中按需读取数据,CPU在完成数据准备后即可转移到其他任务上,提高了系统的整体效率。

举例:以打印机为例:

  1. 直接通信的挑战
    • 如果CPU需要直接将打印内容发送到打印机,则需要等待打印机完成每一行打印。
    • 打印机速度慢,CPU大部分时间会被浪费在等待中。
  2. 通过内存和缓冲解决
    • CPU将需要打印的内容写入内存缓冲区,然后通知打印机。
    • 打印机从缓冲区读取数据并逐步打印,而CPU可以继续执行其他任务。

多任务环境下的资源共享

现代计算机通常运行多个任务,这些任务可能需要同时访问不同的设备。如果CPU直接与设备通信,会导致:

  • 资源冲突:多个任务竞争同一设备可能导致数据错乱或死锁。
  • 缺乏灵活性:任务间无法有效协调设备的使用。

解决方案:通过内存和操作系统管理I/O

  • 内存作为设备与任务之间的中转站,任务将数据写入内存或从内存读取数据,而设备也只与内存交互,避免了任务直接争夺设备资源。
  • 操作系统负责调度设备的访问权限,确保任务之间的协调和安全。

硬件设计复杂性

如果CPU直接与每种I/O设备通信,会导致以下硬件设计上的问题:

  • 多种接口的兼容性问题:CPU必须支持所有设备的物理接口和协议,导致CPU硬件复杂度急剧增加。
  • 难以扩展:引入新设备时,必须修改CPU设计以支持新设备的协议或接口,这会大幅增加设计成本。

解决方案:模块化设计

  • 将I/O设备与CPU解耦,通过内存和I/O控制器(如键盘控制器、磁盘控制器、网卡等)进行通信。
  • CPU通过内存访问统一的设备接口,硬件设计更加模块化,设备的扩展也更加容易。

软件与硬件分离的灵活性

如果CPU直接与设备通信,很多操作都需要通过硬件实现,缺乏灵活性。

  • 硬件实现的功能固定,无法随着需求的变化而灵活调整。
  • 调试和更新硬件协议非常困难。

解决方案:软件驱动程序和内存结合

  • 通过操作系统提供的驱动程序,I/O设备的复杂操作被抽象成统一的接口,CPU只需与内存交互即可。
  • 驱动程序可以通过更新来支持新功能,而无需修改硬件。

数据流动的一致性和清晰性

冯诺依曼体系规定,所有数据必须通过内存中转。这种设计的好处是:

  • 数据流动的统一性:无论是CPU之间的交互,还是设备与CPU之间的交互,所有数据都通过内存传递,数据流动过程清晰可控。
  • 操作的标准化:CPU只需要支持对内存的读写,而不需要知道数据的来源(输入设备)或去向(输出设备),简化了数据处理逻辑。

中断机制的优化

直接通信的另一个问题是,CPU需要轮询(Polling)设备的状态,判断设备是否需要服务。这种方式效率低下,因为CPU需要花费大量时间等待设备准备好。

  • 通过内存配合中断机制
    • I/O设备将数据写入内存后,可以发送中断信号通知CPU。
    • CPU被中断后,读取内存中的数据进行处理。
    • 中断机制避免了CPU轮询设备状态的低效操作,使得CPU可以将资源集中于其他任务。

总结:CPU为何不直接与I/O设备通信?

冯诺依曼体系设计让内存成为数据交互的中枢,其原因包括:

  1. 统一接口:通过内存,CPU只需要支持一种通信模式,避免处理多种设备协议。
  2. 解耦速度差异:缓冲机制减少了CPU因设备慢速而浪费的时间。
  3. 简化硬件设计:设备扩展时无需修改CPU设计,支持更多设备更加灵活。
  4. 提高资源管理效率:操作系统通过内存实现设备共享和调度,提高系统的整体性能。
  5. 降低复杂性:让I/O设备的复杂性由内存和操作系统管理,而不是直接暴露给CPU。

通过这种设计,计算机实现了高效率、模块化、易扩展的系统架构,这也是冯诺依曼体系的伟大之处。

并且如果使用CPU的话,不仅仅效率逐渐增加,价格也逐渐增加,越靠近CPU价格越高,如果程序过大直接加载到CPU的设计会非常昂贵,通过内存的设计,使得计算机成为高性价比的机器,使计算机走进千家万户。

实际案例:登录QQ并与朋友聊天的数据流

为了更好地理解冯诺依曼体系,我们以一个实际应用为例,分析数据在体系中的流动过程。

场景一:登录QQ并发送聊天消息

1. 用户输入账号和密码
  • 用户通过键盘输入账号和密码。
    • 键盘作为输入设备,将数据通过输入单元传递给内存。
    • 数据被写入到内存的指定区域,等待CPU处理。
2. CPU处理登录信息
  • CPU从内存中读取账号和密码,执行一系列指令来验证登录。
    • 登录验证逻辑由程序提供的指令控制,CPU按照指令顺序从内存中取指令并执行。
    • 验证过程可能涉及:
      • 加密密码(如MD5/SHA哈希)。
      • 比较用户输入的账号与数据库记录。
      • 验证结果会写回内存。
3. 登录成功,加载聊天界面
  • 当验证成功后,系统会加载聊天窗口的界面数据。
    • CPU从内存中读取聊天界面模板和用户信息,并生成实际显示的内容。
    • 显示器作为输出设备,从内存读取生成的界面数据,并展示给用户。
4. 发送聊天消息
  • 用户在聊天窗口输入文字消息。
    • 键盘输入数据进入内存。
    • CPU读取输入的文字,并调用网络模块指令,将消息发送到服务器。
    • 发送消息的实际数据通过网络接口卡(网卡)写入内存后,由网络协议栈处理并发送。
5. 对方接收消息
  • 对方的计算机通过网络接收到消息。
    • 数据先写入对方计算机的内存。
    • CPU读取内存中的消息,按照指令将消息处理后传递给输出设备(如屏幕)显示。

场景二:在QQ上发送文件

发送文件的过程与发送消息类似,但涉及数据量更大,流动过程如下:

1. 用户选择文件
  • 用户通过操作系统的文件管理器选择文件。
    • 文件的元信息(如路径、大小等)通过输入设备(如鼠标)写入内存。
    • CPU读取内存中的文件信息,并调用程序指令(如打开文件)获取文件内容。
2. 文件内容加载到内存
  • 操作系统从硬盘中读取文件数据,写入内存。
    • 文件数据分块读取,操作系统通过文件系统管理硬件与内存的交互。
    • CPU控制整个过程,确保数据块正确加载。
3. 文件传输到网络设备
  • CPU将内存中的文件数据传递给网络设备(如网卡),通过网络协议发送到服务器或对方计算机。
    • 文件数据经过分片和打包(如TCP/IP协议处理),数据块通过网卡输出。
4. 对方接收并保存文件
  • 文件数据通过网络传输到对方计算机。
    • 数据写入对方内存,CPU控制文件的重组和存储。
    • 最终文件保存到硬盘中,等待用户查看。

冯诺依曼体系在现代计算机中的意义

尽管冯诺依曼体系自提出以来已经经历了几十年的发展,但其核心思想依然是现代计算机的基础。以下是其实际意义:

1. 统一的存储模型

数据与指令的统一存储简化了计算机的设计,使得程序可以动态加载和修改。

2. 模块化设计

冯诺依曼体系的模块化思路(输入、处理、存储、输出)奠定了现代计算机的设计规范,便于扩展和维护。

3. 软硬件分离

CPU仅通过内存与外设通信,实现了硬件与软件的分离,操作系统和应用程序可以独立开发。

4. 将价格打下来!

不需要昂贵的更大规格的CPU即可实现高性能,使计算机走进千家万户。


总结

冯诺依曼体系的核心是通过存储器将输入、处理和输出串联起来,形成数据的统一流动模式。在现代计算机中,这一架构通过操作系统的调度和优化,以及硬件设备的协同工作,推动了复杂功能的实现。无论是简单的聊天消息还是大文件的传输,数据流的本质仍然符合冯诺依曼的设计思想——所有设备都通过存储器间接与CPU交互,统一管理数据流动

从历史到现在,冯诺依曼体系始终是计算机技术发展的基石,它的影响无处不在,也是我们理解现代计算机的基础。以上就是关于操作系统入门学习中对冯诺依曼体系的讲解。


http://www.kler.cn/a/505743.html

相关文章:

  • 【matlab】matlab知识点及HTTP、TCP通信
  • 【Linux 36】多路转接 - epoll
  • VSCode连接Github的重重困难及解决方案!
  • 【HTML+CSS+JS+VUE】web前端教程-36-JavaScript简介
  • Android string.xml中特殊字符转义
  • LeetCode 热题 100_从前序与中序遍历序列构造二叉树(47_105_中等_C++)(二叉树;递归)
  • DNS介绍(1):基本概念
  • 如何确保API调用安全
  • Flink (三):核心概念(并行度、算子链、任务槽)
  • 算法面试准备 - 手撕系列第一期 - Softmax
  • WPF-01理解XAML
  • 不用PLC和板卡,一台电脑就可以控制伺服
  • Vue.js 动态组件与异步组件
  • 字典和 JSON 文本的格式区别
  • 【漫话机器学习系列】044.热点对特性的影响(Effect Of One Hot On Feature Importance)
  • Rust 正则表达式完全指南
  • zerox - 使用视觉模型将 PDF 转换为 Markdown
  • 机器学习中的凸函数和梯度下降法
  • 海康MV-EB435i立体相机SDK安装(ROS 2)
  • 瑞芯微 RK 系列 RK3588 使用 ffmpeg-rockchip 实现 MPP 视频硬件编解码-代码版
  • 设计模式学习手册(四)(原型模式)
  • C++—17、C++ 中的类和结构体的区别
  • 《计算机网络》课后探研题书面报告_了解PPPoE协议
  • 基于Springboot: 宠物小程序开发笔记(上)
  • Unity2017 控制.abc格式的三维动画播放
  • Kylin Linux V10 替换安装源,并在服务器上启用 EPEL 仓库