【linux】冯诺依曼架构

Alt

🔥个人主页Quitecoder

🔥专栏linux笔记仓

Alt

目录

    • 01.冯诺依曼体系结构
    • 02.操作系统(Operator System)
      • 如何理解“管理”
      • 操作系统中实现“管理的先描述再组织”
    • 03.系统调用与库函数
      • 系统调用
      • 库函数

01.冯诺依曼体系结构

我们常见的计算机,如笔记本。我们不常见的计算机,如服务器,大部分都遵守冯诺依曼体系
在这里插入图片描述
截至目前,我们所认识的计算机,都是由一个个的硬件组件组成

  • 输入单元:包括键盘, 鼠标,扫描仪, 写板等
  • 中央处理器(CPU):含有运算器控制器
  • 输出单元:显示器,打印机等

关于冯诺依曼,必须强调几点:

  • 这里的存储器指的是内存
  • 不考虑缓存情况,这里的CPU能且只能对内存进行读写,不能访问外设(输入或输出设备)
  • 外设(输入或输出设备)要输入或者输出数据,也只能写入内存或者从内存中读取

一句话,所有设备都只能直接和内存打交道

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
冯·诺依曼架构是现代计算机的基础,其核心是将程序存储在计算机内存中并按顺序执行。数据流的理解涉及如何处理、存储和传输数据。下面我们通过使用QQ聊天和发送文件的例子来探讨这一过程。

  1. 登录QQ
  • 启动QQ应用: 当你点击QQ图标时,操作系统加载QQ程序到RAM中。
  • 程序执行: CPU开始执行程序代码,包括初始化网络连接、用户界面等。
  • 登录过程: 输入用户名和密码后,QQ客户端将这些信息封装成数据包,通过互联网发送到QQ服务器。
  • 身份验证: 服务器检查凭证,验证成功后返回登录成功的信息,并可能包括好友列表、聊天记录等数据。
  1. 发送消息
  • 打开聊天窗口: 选择一个好友开始聊天,此时客户端可能从本地缓存或服务器加载历史聊天记录。
  • 输入并发送消息: 输入文本并点击发送,QQ客户端将消息数据打包,并标记发送目标(好友的唯一标识符)。
  • 数据传输: 数据包通过你的网络连接发送到QQ服务器。
  • 服务器处理: 服务器接收到数据包,解析并确定接收者,然后将消息转发到对应的接收者。
  • 好友接收消息: 好友的QQ客户端通过其网络连接从服务器接收到消息,然后在其聊天窗口显示。
  1. 发送文件
  • 选择并发送文件: 在聊天窗口中选择文件发送选项,选择一个文件后,客户端会先读取文件内容。
  • 文件上传: 客户端可能会将文件分割成多个数据包,这些数据包依次上传到QQ服务器。
  • 文件存储: 服务器接收到所有文件数据后,将文件暂存到服务器上。
  • 通知接收方: 服务器向接收方的客户端发送有文件传来的通知,可能包括文件名、大小和下载链接。
  • 文件下载: 接收方可以选择接收并下载文件。点击下载后,客户端通过服务器提供的链接请求文件数据。
  • 文件传输完成: 文件数据通过网络传输到接收方的设备上,存储于指定位置,完成整个文件发送和接收过程。

在这整个过程中,数据流的管理和优化是至关重要的。这包括数据包的正确打包、有效的网络传输、数据安全和隐私保护等。通过这些例子,可以看到冯·诺依曼架构如何支持复杂的数据处理和传输活动,从而使得应用程序如QQ能够高效、安全地运行

02.操作系统(Operator System)

任何计算机系统都包含一个基本的程序集合,称为操作系统(OS)。它是计算机系统中最基本的系统软件,提供了用户与整个计算机系统交互的基础环境。笼统的理解,操作系统包括:

  • 内核(进程管理,内存管理,文件管理,驱动管理)
  • 其他程序(例如函数库,shell程序等等)

计算机系统体系结构成层状分布,操作系统起到承上启下的作用
在这里插入图片描述
设计OS的目的:

  • 与硬件交互,管理所有的软硬件资源
  • 为用户程序(应用程序)提供一个良好的执行环境

在计算机系统中,操作系统(OS)的核心角色可以理解为一个“管理者”。操作系统的管理功能涵盖了多个层面,主要包括对计算机硬件资源和软件应用的管理。这些资源包括CPU(中央处理器)、内存、存储设备和输入/输出设备等。以下是操作系统在这些方面的管理职责:

如何理解“管理”

“管理”在操作系统的语境中,指的是对计算机系统资源的有效分配、监控和调度,以确保系统的稳定运行和高效性能。操作系统通过一系列的程序和策略来实现这些管理任务,从而使得多个程序和用户可以高效、安全地共享计算机资源。

管理的例子

  1. 进程管理:操作系统负责创建、执行、暂停和终止进程。同时,它还负责进程间的同步和通信。
  2. 内存管理:操作系统管理所有程序在运行时的内存需求,确保每个程序获得足够的内存,并处理虚拟内存和物理内存之间的映射。
  3. 文件系统管理:操作系统负责文件的创建、删除、读取和写入。它管理磁盘空间的分配和文件的存储,提供用户级别的文件访问权限。
  4. 设备管理:操作系统通过设备驱动程序管理所有的硬件设备,如键盘、鼠标、硬盘等,控制硬件设备的数据输入输出操作。
  5. 用户界面提供:操作系统提供了与用户交互的界面,如命令行界面(CLI)或图形用户界面(GUI),让用户能够更方便地与计算机系统交互。

被操作系统管理的对象主要包括:

  • 硬件资源:CPU、内存、存储设备(硬盘、SSD等)、输入输出设备(键盘、鼠标、显示器等)。
  • 软件资源:应用程序、系统服务、用户数据和系统数据。

操作系统通过各种数据结构(如表格、队列和树)来组织被管理的对象

  • 进程表:用来跟踪各个进程的状态和资源占用。
  • 内存映射:包括虚拟内存地址到物理内存地址的映射。
  • 文件目录结构:用树状结构来组织文件系统中的文件和目录。
  • 设备队列:管理各个设备请求的队列,确保高效的资源访问。

通过这些管理职责,操作系统确保了计算机系统的高效、稳定和安全运行,允许用户和应用程序更好地执行其任务。

在操作系统的上下文中,管理的“先描述再组织”原则可以被解释为首先定义和明确资源或任务的特征,然后根据这些定义来规划和优化资源的分配和任务的调度。操作系统作为计算机系统资源的管理者,必须精确地理解各种资源的状态、需求和优先级,然后才能有效地组织和调配这些资源以满足系统和用户的需求。这一原则确保了资源使用的最大效率和系统性能的优化。

操作系统中实现“管理的先描述再组织”

  1. 资源描述

    • 硬件资源:如CPU、内存、存储设备和输入输出设备。操作系统需要详细识别每个硬件资源的特性,包括类型、性能参数、当前状态和使用情况。
    • 软件资源:如进程、线程、文件系统等。操作系统通过描述这些资源的属性(如进程的优先级、线程的状态、文件的权限等)来管理它们。
  2. 资源组织

    • 进程管理:操作系统首先通过进程表来描述所有进程的状态和属性。然后,基于这些描述信息,操作系统调度进程运行,管理它们的生命周期,优化CPU的使用效率。
    • 内存管理:操作系统描述每个内存块的状态(如已分配、空闲)、大小和位置。根据这些描述,操作系统通过内存分配算法(如分页、分段)来有效地组织内存资源,确保每个应用程序和服务都能得到所需的内存。
    • 文件管理:操作系统描述文件和目录的结构、权限和位置,然后根据这些信息来组织文件存储、执行文件访问控制和数据备份。
  3. 任务调度

    • 描述任务需求:操作系统描述每个任务的资源需求、优先级和截止时间。
    • 组织和调度:根据这些描述,操作系统安排任务执行的顺序,优化资源分配,以达到最小化响应时间、最大化吞吐量或其他优化目标。
  4. 性能管理

    • 系统监控:操作系统通过持续监控和描述系统性能参数(如CPU利用率、内存使用、IO操作等),获取系统运行的实时画像。
    • 资源再组织:根据性能监控的数据,操作系统可能会重新组织资源,调整任务优先级,或平衡负载,以保持系统性能的最优化。

通过这种方式,“先描述再组织”的管理策略帮助操作系统在不断变化的需求和资源状态中保持高效和稳定。这不仅优化了资源的使用,还提高了系统的整体性能和用户的满意度

03.系统调用与库函数

在理解操作系统和应用程序交互时,系统调用库函数是两个核心概念,它们在功能和执行层面有明显的差异。
在这里插入图片描述
如果我们开发直接调用系统调用接口,这样的代码我们成它不具有跨平台性

系统调用

系统调用是应用程序与操作系统之间的接口,是程序在执行期间请求操作系统提供特定服务的一种方式。这些服务包括硬件操作、创建和执行进程、管理文件系统等底层操作。系统调用允许用户级应用程序执行通常不允许的操作,确保系统稳定性和安全性。

  • 特点
    • 权限层级: 系统调用在较低的权限层级执行,通常是操作系统的核心层级。
    • 功能范围:涵盖底层硬件管理、进程控制、文件操作等。
    • 执行过程:执行系统调用时,CPU从用户模式切换到内核模式,这是一种权限升级。

库函数

库函数是一些预先编写好的、可以在程序中直接调用的函数,通常由各种标准或非标准库提供,如C标准库(libc),提供字符串处理、文件操作、数学计算等功能。库函数可以包含系统调用,但也可以只是执行算法或其他计算任务而不直接请求操作系统资源。
在这里插入图片描述

  • 特点

    • 权限层级:库函数通常在用户模式下执行,不涉及模式的切换。
    • 功能范围:可以非常广泛,从简单的数学计算到复杂的图形渲染等。
    • 依赖性:库函数可能调用系统调用来执行底层操作,如文件I/O。
  • 系统调用示例:open()read()write()fork()exec()等是典型的系统调用,它们直接与操作系统内核交互,管理硬件资源或进程等。

  • 库函数示例:printf()strcpy()malloc()等。这些函数可能在内部使用系统调用,例如printf()最终会调用write()系统调用来输出数据到标准输出,而malloc()可能会调用brk()mmap()系统调用来分配内存。

理解系统调用和库函数之间的区别对于系统编程和应用程序开发非常重要,因为它们影响代码的性能、安全性和可移植性。系统调用因涉及模式切换而通常比库函数调用成本更高;同时,对系统资源的直接控制能力也使得系统调用更加强大但使用时需要更加小心。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/889376.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Win10 IDEA连接虚拟机中的Hadoop(HDFS)

获取虚拟机的ip 虚拟机终端输入 ip a关闭虚拟机防火墙 sudo ufw disable修改Hadoop的core-site.xml文件 将localhost修改为虚拟机局域网IP # 位置可能不一样,和Hadoop安装位置有关 cd /usr/local/hadoop/etc/hadoop vim core-site.xmlIDEA 连接 创建Maven项目…

【图论】(二)图论基础与路径问题

图论基础与路径问题 图的构造邻接矩阵邻接表 所有可达路径邻接矩阵存储邻接表存储 字符串接龙有向图的完全可达性 图的构造 这里仅对图论路径问题中图的构造做整理总结归纳,具体详细相关概念请参考代码随想录上的整理总结: 图论理论基础深度优先搜索理…

【万字长文】Word2Vec计算详解(一)CBOW模型

【万字长文】Word2Vec计算详解(一)CBOW模型 写在前面 本文用于记录本人学习NLP过程中,学习Word2Vec部分时的详细过程,本文与本人写的其他文章一样,旨在给出Word2Vec模型中的详细计算过程,包括每个模块的计…

jmeter学习(7)beanshell

beanshell preprocessor 发送请求前执行 beanshell postprocessor 发送请求前执行 获取请求相关信息 String body sampler.getArguments().getArgument(0).getValue(); String url sampler.getPath(); 获取响应报文 String responseprev.getResponseDataAsString(); 获…

论文翻译 | Fairness-guided Few-shot Prompting for LargeLanguage Models

摘要 大型语言模型已经显示出令人惊讶的执行上下文学习的能力,也就是说,这些模型可以通过对由几个输入输出示例构建的提示进行条件反射,直接应用于解决大量下游任务。然而,先前的研究表明,由于训练示例、示例顺序和提示…

熵权法计算评价指标权重——使用Excel VBA实现

[ 熵权法 ] 信息是系统有序程度的一个度量,熵是系统无序程度的一个度量;根据信息熵的定义,对于某项指标,可以用熵值来判断某个指标的离散程度,其信息熵值越小,指标的离散程度越大, 该指标对综合…

科研绘图系列:R语言绘制SCI文章图2

文章目录 介绍加载R包导入数据图a图b图d系统信息介绍 文章提供了绘制图a,图b和图d的数据和代码 加载R包 library(ggplot2) library(dplyr) library(readxl) library(ggpmisc)导入数据 数据可从以下链接下载(画图所需要的所有数据): 百度网盘下载链接: https://pan.baid…

遍历有向图链路(DFS算法)- 优化版

在上一节基础上,去除了节点的pre集合,只保留节点next的结合,对数据模型进行了优化,实现思想做了优化。 有向图示例: 基本思路 构建有向图数据模型校验有向图不能出现回路,即当前节点不能出现在历史链路中首…

股指期货的杠杆是怎么体现和使用的?

股指期货的杠杆效应是通过保证金交易实现的。投资者只需支付合约价值的一小部分作为保证金,即可控制整个合约的价值。例如,如果一个股指期货合约的价值为100,000元,而保证金比例为10%,那么投资者只需支付10,000元即可控制这个合约…

SpringBoot教程(二十四) | SpringBoot实现分布式定时任务之Quartz(基础)

SpringBoot教程(二十四) | SpringBoot实现分布式定时任务之Quartz(基础) 简介适用场景Quartz核心概念Quartz 存储方式Quartz 版本类型引入相关依赖开始集成方式一:内存方式(MEMORY)存储实现定时任务1. 定义任务类2. 定…

从commit校验失效问题探究husky原理

一、背景 之前创建的项目,发现代码 commit 提交的时候没有了任何校验,具体表现: 一是 feat fix 等主题格式校验没有了二是代码 lint 不通过也能提交 尝试解决这个问题,并深入了解husky的实现原理,将相关的一些知识点…

【Vue】Vue扫盲(三)计算属性和监听器

【Vue】Vue扫盲(一)事件标签、事件修饰符:click.prevent click.stop click.stop.prevent、按键修饰符、及常用指令 【Vue】Vue扫盲(二)指令:v-for 、v-if、v-else-if、v-else、v-show 文章目录 1、 计算属…

用FPGA做一个全画幅无反相机

做一个 FPGA 驱动的全画幅无反光镜数码相机是不是觉得很酷? 就是上图这样。 Sitina 一款开源 35 毫米全画幅 (3624 毫米) CCD 无反光镜可换镜头相机 (MILC),这个项目最初的目标是打造一款数码相机,将 SLR [单镜头反光] 相机转换为 DSLR [数码…

Spring事务的1道面试题

每次聊起Spring事务,好像很熟悉,又好像很陌生。本篇通过一道面试题和一些实践,来拆解几个Spring事务的常见坑点。 原理 Spring事务的原理是:通过AOP切面的方式实现的,也就是通过代理模式去实现事务增强。 具体过程是…

【3dgs】总结3DGS与NeRF如何重塑SLAM24年4月最新进展

【3dgs】总结3DGS与NeRF如何重塑SLAM! 1. 摘要2. 简洁3. 背景3.1 Existing SLAM Surveys3.2 progress in Radiance Field Theory3.3.1 NeRF3.3.2 3dgs3.4 数据集 4 数据集4.1 SLAM3.1 RGB-D SLAM方法3.1.1 基于NeRF风格的RGB-D SLAM3.1.2 基于3DGS风格的 RGB-D SLAM…

opencv的相机标定与姿态解算

首先我们要知道四个重要的坐标系 世界坐标系相机坐标系图像成像坐标系图像像素坐标系 坐标系之间的转换 世界坐标系——相机坐标系 从世界坐标系到相机坐标系,涉及到旋转和平移(其实所有的运动也可以用旋转矩阵和平移向量来描述)。绕着不…

Python编程:创意爱心表白代码集

在寻找一种特别的方式来表达你的爱意吗?使用Python编程,你可以创造出独一无二的爱心图案,为你的表白增添一份特别的浪漫。这里为你精选了六种不同风格的爱心表白代码,让你的创意和情感通过代码展现出来。 话不多说,咱…

C++开发五子棋游戏案例详解

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…

MSYS2+GCC 安装与应用保姆手册

msys2 提供可在Windows下使用 GCC 编译器;并且,借助 Linux 包管理功能,可轻松下载丰富的可在Windows下直接使用的 C/C 开发包,包括编译好的二进制包。 网络库asio、准标准库boost、zip解压缩、json格式处理、引擎 SDL……十八般兵…

图片美化SDK解决方案,赋能H5与小程序极致体验

无论是社交媒体分享、电商产品展示,还是个人日常生活的记录,一张经过精心美化的图片总能瞬间吸引眼球,传递出更加丰富和动人的信息。如何在不增加应用体积、不牺牲用户体验的前提下,为H5页面和小程序提供媲美原生APP的图片美化功能…