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

约翰·冯诺依曼(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.rhkb.cn/news/2524.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenCV实现Kuwahara滤波

Kuwahara滤波是一种非线性的平滑滤波技术,其基本原理在于通过计算图像模板中邻域内的均值和方差,选择图像灰度值较为均匀的区域的均值来替代模板中心像素的灰度值。以下是Kuwahara滤波的详细原理说明: 一、基本思想 Kuwahara滤波的基本思想…

vue项目引入阿里云svg资源图标

1:生成svg图标 登录阿里云官网 1.1 创建项目组 1.2 从阿里云网站上面获取喜欢的图标加入到已有的项目组 1.3 如果团队有自己的设计师,也可以让设计师上传自己的svg图标到阿里云指定的项目组; 使用的时候,把 资源包下载到本地项…

软件测试 —— 自动化测试(Selenium)

软件测试 —— 自动化测试(Selenium) 什么是SeleniumPython安装Selenium1.安装webdirver-manager2.安装Selenium 写一个简单用例CSS_SELECTOR和XPATH浏览器快速定位页面元素浏览器的前进(forward),后退(bac…

新垂直电商的社交传播策略与AI智能名片2+1链动模式S2B2C商城小程序的应用探索

摘要:随着互联网技术的不断进步和电商行业的快速发展,传统电商模式已难以满足消费者日益增长的个性化和多元化需求。新垂直电商在此背景下应运而生,通过精准定位、用户细分以及深度社交传播策略,实现了用户群体的快速裂变与高效营…

Jmeter进行http接口并发测试

目录: 1、Jmeter设置(1)设置请求并发数(2)设置请求地址以及参数(3)添加结果数 2、启动看结果 1、Jmeter设置 (1)设置请求并发数 (2)设置请求地址…

有一台服务器可以做哪些很酷的事情

有一台服务器可以做哪些很酷的事情 今天我也来简单分享一下,这几年来,我用云服务器做了哪些有趣的事情。 服务器推荐 1. 个人博客 拥有个人服务器,你可以完全掌控自己的网站或博客。 与使用第三方托管平台相比,你能自由选择网站…

链家房价数据爬虫和机器学习数据可视化预测

完整源码项目包获取→点击文章末尾名片!

从网络的角度来看,用户输入网址到网页显示,期间发生了什么?

步骤(总体来看) 浏览器根据输入网页的URL进行解析,解析出对应的请求方式、URL、端口等,生成HTTP请求报文。浏览器查询缓存,检查缓存是否已经存在该URL的资源,如果缓存命中中直接读取并显示,比如…

MYSQL创建表

1.要求 2.步骤 1.创建数据库: create database mydb6_product;2.使用数据库: use mydb6_product;3.创建employees表: create table employees(id int primary key,name varchar(50) not null, age int not null,gender varchar(10) not null default unknown&…

计算机网络的五层协议

计算机网络的五层协议 ‌计算机网络的五层协议模型包括物理层、数据链路层、网络层、传输层和应用层,每一层都有其特定的功能和相关的协议。‌‌1 ‌物理层‌:负责传输原始的比特流,通过线路(有线或无线)将数据转换为…

C语言初阶习题【30】字符串左旋

1. 题目描述——字符串左旋 实现一个函数,可以左旋字符串中的k个字符。 例如: ABCD左旋一个字符得到BCDA ABCD左旋两个字符得到CDAB 2. 思路 先思考了下如何把最前面的字符串移到后面。 思路比较简单,就是把第一个字符保存下来&#xf…

ESP8266固件烧录

一、烧录原理 1、引脚布局 2、引脚定义 3、尺寸封装 4、环境要求 5、接线方式 ESP8266系列模块集成了高速GPI0和外围接口,这可能会导致严重的开关噪声。如果某些应用需要高功率和EMI特性,建议在数字I/0线上串联10到100欧姆。这可以在切换电源时抑制过冲…

word-break控制的几种容器换行行为详解

word-break 属性在控制换行行为时需要根据语言判断,对于中文 一个字符就是一个单词,字符换行不影响阅读理解,而对于英文来说,多个连续的字符才会是一个单词,例如中文的 早 英文为 morning。 morning7个字符才算一个单词…

年后找工作需要注意的事项

大家好!我是 [数擎 AI],一位热爱探索新技术的前端开发者,在这里分享前端和 Web3D、AI 技术的干货与实战经验。如果你对技术有热情,欢迎关注我的文章,我们一起成长、进步! 开发领域:前端开发 | A…

Flink链接Kafka

一、基于 Flink 的 Kafka 消息生产者 Kafka 生产者的创建与配置: 代码通过 FlinkKafkaProducer 创建 Kafka 生产者,用于向 Kafka 主题发送消息。Flink 执行环境的配置: 配置了 Flink 的检查点机制,确保消息的可靠性,支…

Windows 10 ARM工控主板连接I2S音频芯片

在Windows工控主板应用中,音频功能是一项基本的需求,USB声卡在x86/x64 Windows系统上就可直接免驱使用,但这些USB声卡通常不提供ARM上的Windows系统驱动。本文将介绍如何利用安装在ARM上的Windows工控主板——ESM8400的I2S接口、连接WM8960音…

机器学习实战33-LSTM+随机森林模型在股票价格走势预测与买卖点分类中的应用

大家好,我是微学AI,今天给大家介绍一下机器学习实战33-LSTM随机森林模型在股票价格走势预测与买卖点分类中的应用。对于LSTM随机森林模型的融合应用,我们选择股票价格走势预测与买卖点分类作为应用场景。股票市场数据丰富且对投资者具有实际价…

在VS2022中用C++连接MySQL数据库读取数据库乱码问题

1.正确安装mysql 安装之后的配置文件 2.在VS2022中进行相关配置 (1)右键项目,打开属性 注意是右键项目,不是.cpp文件 (2)配置属性-> VC目录 -> 包含目录 ->添加头文件路径(如图&am…

vue3+ts+element-plus 输入框el-input设置背景颜色

普通情况&#xff1a; 组件内容&#xff1a; <el-input v-model"applyBasicInfo.outerApplyId"/> 样式设置&#xff1a; ::v-deep .el-input__wrapper {background-color: pink; }// 也可以这样设置 ::v-deep(.el-input__wrapper) {background-color: pink…

Realsense相机驱动安装及其ROS通讯配置——机器人抓取系统基础系列(四)

文章目录 概要1 Realsense相机驱动安装Method1: 使用Intel服务器预编译包Method2: 使用ROS服务器预编译包Method3: 使用SDK源代码方法对比总结 2 Realsense-ROS通讯配置与使用2.1 Realsense-ROS包安装2.2 ROS节点启动 小结Reference 概要 本文首先阐述了Realsense相机驱动安装…