计算机系统漫游

重点理解部分:

  1. 系统硬件:对硬件如处理器、存储器、I/O设备有一个基本的认识,理解它们的基本工作原理以及它们是如何协同工作的。
  2. Hello,World程序运行的过程:了解一个C程序如何从源代码到最终在计算机上运行的全过程。其中包括预处理、编译、汇编和链接等步骤。这个过程对于理解计算机系统来说非常重要。
  3. 处理器读取和解释存储在内存中的指令:理解指令是如何被加载到内存,处理器是如何获取和执行这些指令的。
  4. 缓存和内存的层次结构:理解缓存、主存和硬盘等不同级别存储设备之间的关系,为什么会有这样的层次结构,以及它们对程序性能的影响。
  5. 操作系统管理硬件:如何管理进程,文件和网络。理解系统调用和它们如何与硬件交互。
  6. 系统之间的网络通信:理解互联网是如何工作的,计算机是如何通过网络来交换信息的。
  7. 重要的系统级概念:并发和并行,这两个概念在计算机系统中非常重要,理解它们的含义和区别,以及它们在现代计算机系统中的应用。

不过在第一章内容中,不需要立即掌握上述内容,在后续继续学习过程中,会有更深入的了解。我相信哈…

系统硬件

系统硬件:计算机系统主要由处理器(CPU)、存储器(RAM)、和输入输出设备(I/O设备)组成。CPU负责执行程序指令,进行运算和控制操作;RAM存储正在运行的程序和数据;I/O设备负责与外部世界进行信息交互,例如键盘、鼠标、显示器等。

总线(Bus):贯穿整个系统的一组电子管道,它将处理器、内存和I/O设备链接起来,并携带信息字节在这节部件间传递。

I/O设备(Input/Output Devices):是系统与外界的联系通道。包括各种输入设备(如键盘、鼠标)、输出设备(如显示器、打印机)以及存储设备(如硬盘、光盘驱动器)。这些设备可以通过总线与处理器和内存进行通信,也可以通过DMA(Direct Memory Access,直接内存访问)方式访问主存,这可以在不占用CPU的情况下,直接在I/O设备和主存之间传输数据。

主存(Main Memory):也称作内存,是一个临时存储设备,主要用于存储正在运行的程序以及其所需要处理的数据。

处理器(Processor):也称为中央处理器(CPU),它是计算机的运算核心和控制核心。它是一个字长大小的存储设备或寄存器,始终指向主存中的某条机器语言指令。

处理器的工作过程:

  1. 指令读取:处理器首先从程序计数器(PC)指向的存储器处读取指令。
  2. 指令解释:然后处理器会解释指令中的位。
  3. 指令执行:之后,处理器会执行指令指示的简单操作。
  4. 更新程序计数器:最后,处理器更新程序计数器指向下一条指令。这条指令并不一定在存储器中与刚刚执行的指令相邻。

处理器可以执行的操作类型包括:

  • 加载:从主存中复制一个字节或一个字到寄存器,替代寄存器原来的内容。
  • 存储:从寄存器复制一个字节或一个字到主存的某个位置,替代该位置原来的内容。
  • 更新:复制两个寄存器的内容到算术逻辑单元(ALU),ALU将两个字相加,并将结果存放到一个寄存器中,替代该寄存器原来的内容。
  • I/O读:从一个I/O设备中复制一个字节或一个字到一个寄存器。
  • I/O写:从一个寄存器复制一个字节或一个字到一个I/O设备。
  • 转移:从指令本身中抽取一个字,并将这个字复制到程序计数器(PC)中,替代PC中原来的值。

image-20230526165335191

编译过程

Hello, World程序运行的过程

  • 预处理:预处理器(cpp)按照你在源代码中的指示修改代码。例如解析#include#define等预处理指令。即将hello.c处理成hello.i。

  • 编译:编译器(cc1)将预处理过的C源代码(hello.i)翻译成汇编语言(hello.s)。

  • 汇编:汇编器(as)将汇编语言翻译成机器语言指令,生成可重定位目标文件(hello.o)。

  • 链接:链接器(ld)将目标文件与库文件链接在一起,生成一个可执行文件。

image-20230526165632096

存储器层次结构

image-20230526173302709

计算机系统中的存储设备按照它们的存取速度和容量组织成了一个层次结构,这就存储器层次结构

存储器层次结构的主要思想是一个层次的存储器作为下一层次上的存储器的告诉缓存。这个结构从顶到底分别是:寄存器、高速缓存(Cache)、主存(Main Memory)、磁盘存储(Disk Storage)以及备份存储(Backup Storage)。

  1. 寄存器:位于CPU内部,有着最快的访问速度,但数量有限,成本最高。
  2. 高速缓存(Cache):位于CPU和主存之间,设计用于存储由CPU频繁访问的数据,以减少CPU和主存之间的数据传输。高速缓存分为几级,L1 Cache最接近CPU,访问速度最快但容量最小,然后是L2、L3 Cache,访问速度逐级下降,容量逐级增大。
  3. 主存(Main Memory):也称为RAM,是用来存储正在运行的程序和数据的。相比于寄存器和Cache,主存的访问速度较慢,但容量较大,价格较便宜。
  4. 磁盘存储(Disk Storage):也称为硬盘,是一种非易失性存储设备,用于长期存储数据和程序。相比于主存,磁盘的访问速度更慢,但容量更大,价格更便宜。
  5. 备份存储(Backup Storage):如磁带、云存储等,主要用于数据备份和灾难恢复,其速度最慢,但成本最低,容量最大。

存储器层次结构存在的主要原因是处理器和存储器之间的“速度差距”。处理器的速度远远超过了存储器的速度,如果没有Cache,那么处理器就会花大量的时间在等待数据存取上,这就是所谓的存储器壁垒(Memory Wall)问题。通过引入Cache,我们可以将常用的数据保存在接近CPU速度的存储器中,从而大大提高程序的运行效率。

操作系统

操作系统可以看成应用程序和硬件之前插入的一层软件,所有应用程序对硬件的操作都必须通过操作系统。

image-20230526174234829

操作系统有两个基本功能:

  • 防止硬件被失控的应用程序滥用
  • 在控制复杂而又通常广泛不同的低级硬件设备方面,为应用程序提供简单一致的方法。

操作系统通过下图显示的抽象概念(进程、虚拟存储器、文件)实现这两个功能。

image-20230526175604390

进程

进程:是操作系统对运行程序的一种抽象。当你运行一个程序时,操作系统会创建一个新的进程来执行它。这个进程看起来好像它是独占的,即它有自己的处理器、内存和I/O设备。实际上,操作系统允许多个进程并发运行,交错执行每个进程的指令,创建出它们各自独占硬件的假象。

这种并发运行的实现是通过操作系统的一种机制:上下文切换。操作系统保存每个进程运行所需的所有状态信息,即上下文,这包括程序计数器(PC)和寄存器文件的当前值,以及主存的内容。当操作系统决定从当前进程切换到另一个进程时,它会保存当前进程的上下文,恢复新进程的上下文,然后将控制权交给新进程。新进程就会从上次停止的地方开始运行。

例如,当你在shell中运行hello程序时,最初只有shell进程在运行,等待你的输入。当你让它运行hello程序时,shell通过调用一个系统调用来执行你的请求,系统调用会将控制权交给操作系统。操作系统保存shell进程的上下文,创建一个新的hello进程及其上下文,然后将控制权交给hello进程。hello程序运行完毕后,操作系统恢复shell进程的上下文,并将控制权返回给shell,它会继续等待你的输入。

image-20230526181446339

进程这个概念需要硬件和操作系统软件的紧密合作来实现。虽然它为我们提供了一个看似简单的运行环境,但实际上,操作系统和硬件背后的复杂性被隐藏了起来。另外,由于进程的并发执行,时间的概念被打乱了,导致很难获取准确和可重复的运行时间测量。

线程

线程是一个进程内的执行单元,每个线程都在进程的上下文中运行,并共享同一套代码和全局数据。相比于多进程,多线程更易于数据共享,也更为高效。特别是在需要并行处理的场景,如网络服务器,线程就显得尤为重要。

虚拟存储器

虚拟存储器是另一个操作系统的重要抽象。它为每个进程提供了一种假象,即每个进程都在独占地使用主存。每个进程看到的是一致的存储空间,称之为虚拟地址空间。例如,在Linux系统中,虚拟地址空间被分为两部分:底部的四分之三存放用户进程的代码和数据,顶部的四分之一则预留给操作系统的代码和数据。这样的设计使得每个进程都有一致的视角,似乎拥有了整个主存。

image-20230526181957252

虚拟地址空间由多个区组成,每个区都有特定的功能:

  1. 程序代码和数据区:从一个固定的地址开始,包含了程序的代码和与C全局变量相对应的数据区。这些区域的内容直接由可执行目标文件初始化。
  2. :紧接在代码和数据区之后的是运行时堆。与代码和数据区的大小在进程开始时就确定不同,堆可以在运行时动态地扩展和收缩,这主要是通过调用如malloc和free这样的C标准库函数来实现的。
  3. 共享库:在虚拟地址空间的中间部分是存放共享库的代码和数据的区域,如C标准库和数学库等。共享库是一个非常强大的概念,允许多个应用程序共享同一份库的副本,从而节省内存空间。
  4. :位于用户虚拟地址空间顶部的是用户栈,编译器用它来实现函数调用。像堆一样,用户栈在程序执行过程中可以动态地扩展和收缩。每次函数调用时,栈就会增长;每次函数返回时,栈就会收缩。
  5. 内核虚拟存储器:在虚拟地址空间的顶部四分之一部分是预留给内核的,内核是操作系统总是驻留在内存中的部分。应用程序不能直接读写这个区域的内容,或直接调用内核代码定义的函数。

虚拟存储器的运作需要硬件和操作系统软件间的精密复杂的互相合作。基本思想是把一个进程虚拟存储器的内容存储在磁盘上,然后用主存作为磁盘的高速缓存。

网络通信和其他系统级概念

网络是现代计算机系统的核心组成部分,它使得不同的计算机系统可以彼此进行通信和数据交换。从单个系统的视角来看,网络可以被看作是另一种I/O设备,系统可以从主存中复制数据到网络适配器,然后数据通过网络到达另一台机器。相反,系统也可以从网络中读取数据,将数据复制到主存中。

我们可以通过telnet应用在远程主机上运行程序。假设我们在本地主机上的telnet客户端连接到远程主机的telnet服务器,登录并运行shell,然后在shell中输入命令来运行程序。接下来,远程shell将运行程序并将输出返回给telnet服务器,最后,telnet服务器通过网络将输出传输到telnet客户端,客户端将输出显示在我们的本地终端上。

image-20230526182852458

这种在客户端和服务器之间进行交互的方式在所有网络应用中都是非常典型的。我们可以利用这种机制来创建各种网络应用程序,如Web服务器等。

总体来说,网络为计算机系统提供了与其他系统通信的能力,使得数据可以在不同的系统之间传输。这为许多网络应用提供了基础,也极大地提高了计算机系统的功能性和灵活性。

系统之间的网络通信

互联网是一个全球性的计算机网络,它使用TCP/IP协议族来连接全球各地的计算机。在网络通信中,数据被分解为小的数据包,然后通过网络发送到目的地。每个数据包都包含源地址和目标地址,这样它就可以被正确地路由到目的地。

计算机通过网络交换信息的基本过程是这样的:首先,源计算机的操作系统将要发送的信息分解为一个个数据包,并添加TCP/IP头信息,然后通过NIC发送到网络。这些数据包通过网络到达目的地后,目标计算机的操作系统将它们重新组合成原始信息。

在互联网中,还有一些特定的服务和应用程序,如HTTP(用于网页传输)、FTP(用于文件传输)、SMTP(用于电子邮件传输)等,它们都是建立在TCP/IP协议之上的,用来执行特定的网络通信任务。

并发和并行

并发是指一个系统能够处理多个任务的能力。这并不意味着它们会同时运行;而是意味着在同一时间段内,这些任务都在进展,但可能会被分解为更小的子任务,并交替执行。并发常常出现在单核处理器的系统中,通过任务切换(task switching)和时间分片(time slicing)技术,使得单个处理器看起来像是在同时处理多个任务。

并行则是指在同一时刻执行多个任务的能力。这通常需要多个处理器或者多核处理器的支持。在并行计算中,任务会被分解为一些可以独立并行执行的小任务,然后在多个处理器或核心上同时运行。

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

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

相关文章

模仿抖音直播商城带货打赏功能做一个app系统

随着人们生活和互联网的高度整合,越来越多的人开始转变自身消费模式,从实体店购物逐渐转向足不出户即可享受购物快感的网上购物。许多企业看到了电子商务背后隐藏的巨大价值,想要寻找合适的开发商建立属于自己的电商直播系统,那么…

2021-06-10 51单片机,键控流水灯——中断方式

缘由https://ask.csdn.net/questions/7444779?spm1005.2025.3001.5141 #include "reg52.h" sbit K1 P1^5; sbit K2 P1^6; sbit K3 P1^7; bit kk0; void zdsz() {EAEX0IT01; } void main() {unsigned char Xd0;unsigned int ys4747,d10;zdsz();while(1){if(!ys)…

CodeForces..学习读书吧.[简单].[条件判断].[找最小值]

题目描述: 题目解读: 给定一组数,分别是 “时间 内容”,内容分为00,01,10,11四种,求能够得到11的最小时间。 解题思路: 看似00,01,10&#xff0…

C语言中的类型转换

C语言中的类型转换 隐式类型转换 整型提升 概念: C语言的整型算术运算总是至少以缺省(默认)整型类型的精度来进行的为了获得这个精度,表达式中字符和短整型操作数在使用之前被转换为普通整型,这种转换成为整型提升 如…

自学大语言模型之BERT

BERT 模型由 Jacob Devlin、Ming-Wei Chang、Kenton Lee 和 Kristina Toutanova在BERT: Pre-training of Deep Bidirectional Transformers for Language Understanding中提出。它是一种双向变换器,使用掩码语言建模目标和对包含多伦多图书语料库和维基百科的大型语…

C语言---初始C语言

1、初始C语言 1、编译器主要有:Clang、GCC、WIN-TC、MSVC、Turbo C等 什么是编译? test.c----------------------------->test.exe 这个过程需要经过编译、链接等过程,而众多编译器实现的功能就是把我们写的test.c进行编译。 2、VS20…

利用栈和队列共同解决迷宫问题

文章目录 什么是迷宫问题?如何解决迷宫问题?DFS(深度优先搜索)BFS(广度优先搜索) 总结 什么是迷宫问题? 迷宫问题是一道经典的算法问题,旨在寻找一条从起点到终点的最短路径。通常迷…

桶排序 — 计数排序和基数排序

计数排序 int类型数组,其中存的是员工的年龄。比如说16 - 150。对于这样的数据来讲,数据状况是受限的。此时如果将数组从小到大进行排序,该如果实现? 这个实现很简单,实现一个统计数组范围从 0 ~ 150,新数组…

Flume的安装和使用

安装Flume 1.1访问Flume的官网(http://flume.apache.org/download.html),下载Flume安装apache-flume-1.9.0-bin.tar.gz。或者下载我的百度网盘资源。把安装文件解压缩到windows操作“D:\”目录下,然后执行如下命令测试是否安装成…

【JavaSE】Java基础语法(十六):抽象类

文章目录 1. 抽象类的概述2. 抽象类的特点3. 抽象类的实用价值4. 抽象类的案例 1. 抽象类的概述 当我们在做子类共性功能抽取时,有些方法在父类中并没有具体的体现,这个时候就需要抽象类了! 在Java中,一个没有方法体的方法应该定义…

在Linux设备上让程序在任意目录都能执行

目录 0. 前言1. 编写代码2. 创建软链接3. 其他Linux文章 0. 前言 在Ubuntu上使用espidf中往往需要先设置环境变量,再执行export.sh,对环境装的乱七八糟的我造成了很大的不便我希望无论我在哪个目录,都能快速执行某个命令 我先是使用了编写b…

微信小程序开发实战 ⑨(TabBar)

作者 : SYFStrive 博客首页 : HomePage 📜: 微信小程序 📌:个人社区(欢迎大佬们加入) 👉:社区链接🔗 📌:觉得文章不错可以点点关注 &#x1f4…

【Unittest】自动化测试框架核心要素

1、什么是Unittest框架? python自带一种单元测试框架 2、为什么使用UnitTest框架? >批量执行用例 >提供丰富的断言知识 >可以生成报告 3、核心要素: 1). TestCase(测试用例) 2). TestSuite(测试套件)…

WalkRE--刷图流程(超具体)

1、打开WalkRE软件,界面如下: 2、选择“根据模板新建工程”。操作如下: 3、导入数据。需要准备好dxf格式的CAD地形数据。操作如下: 在空白处右键,先关闭所有层(大部分层在刷图时用不上,仅打开刷…

如何监控电动车充电桩能耗?

一 背景 随着新能源汽车的快速发展,像特斯拉、BYD、蔚来、小鹏和理想等品牌的电动汽车在我们的日常生活中越来越多了,可见电动汽车如今已逐渐被我们所认可了。同汽油车需要加油一样,电动汽车需要充电,如此一来,电动汽…

C++进阶 —— multimap

目录 一&#xff0c;multimap介绍 类pair 函数模板make_pair 二&#xff0c;multimap使用 一&#xff0c;multimap介绍 multimap是关联式容器&#xff0c;按照特定顺序存储键值对<key、value>&#xff0c;其中多个键值对之间的key可以重复&#xff1b;键key通常用于排…

供应链 | 在线平台的研究与思考(一):销售渠道与模式选择

封面图来源&#xff1a; https://www.pexels.com/zh-cn/photo/4968391/ 编者按 当前&#xff0c;电商平台主要采用两种销售模式&#xff1a;代理和分销。商家根据自身情况选择线上或线下渠道&#xff0c;而电商平台会根据不同的线上商家选择适当的分销模式。本期编者精选的两…

C++环形缓冲区设计与实现:从原理到应用的全方位解析

C环形缓冲区设计与实现&#xff1a;从原理到应用的全方位解析 一、环形缓冲区基础理论解析&#xff08;Basic Theory of Circular Buffer&#xff09;1.1 环形缓冲区的定义与作用&#xff08;Definition and Function of Circular Buffer&#xff09;1.2 环形缓冲区的基本原理&…

Smartbi“三步走”构建智慧经营分析平台,实现国有企业监管报送和数智化转型

01. 现状与痛点 — 一直以来&#xff0c;国资国企都是促进我国经济高速发展的领头羊&#xff0c;但近年来受疫情冲击和国际经济下行影响&#xff0c;国资企业经营面临较大压力&#xff0c;同时为实现国有企业高质量发展&#xff0c;国务院国资委下发一系列政策要求&#xff…

linuxOPS基础_vmware虚拟机安装及介绍

虚拟机概念 什么是虚拟机&#xff1f; 虚拟机&#xff0c;有些时候想模拟出一个真实的电脑环境&#xff0c;碍于使用真机安装代价太大&#xff0c;因此而诞生的一款可以模拟操作系统运行的软件。 虚拟机目前有2 个比较有名的产品&#xff1a;vmware 出品的vmware workstatio…