网络工程师 (3)指令系统基础

一、寻址方式

(一)指令寻址

顺序寻址:通过程序计数器(PC)加1,自动形成下一条指令的地址。这是计算机中最基本、最常用的寻址方式。

跳跃寻址:通过转移类指令直接或间接给出下一条指令的地址。跳跃寻址的转移地址形成方式有直接(绝对)、相对和间接寻址三种,用于实现程序的分支和循环。

(二)数据寻址

隐含寻址:操作数地址不明显的给出,隐藏在指令中。这种寻址方式简化了指令的格式,但降低了指令的灵活性。

立即寻址:指令中直接给出操作数的值,而不是操作数的地址。这种寻址方式获取操作数最快,因为不需要访问内存。例如,MOV AX,#40H,这条指令将立即数40H传送给通用寄存器AX。

直接寻址:指令中直接给出操作数的地址。例如,MOV A,40H,这条指令将内部RAM中40H地址的内容传送给累加器A。直接寻址方式简单明了,但寻址范围受限。

间接寻址:指令中给出的地址不是操作数的地址,而是存放操作数地址的内存单元的地址。间接寻址方式可以扩大寻址范围,但增加了访问内存的次数,降低了指令的执行速度。间接寻址有一级寻址和多级间接寻址之分,多级间接寻址需要多次访问内存才能得到操作数。

寄存器寻址:指令中直接给出操作数所在的寄存器的编号。寄存器寻址方式访问速度快,因为寄存器通常位于CPU内部,但寄存器数量有限,寻址范围受限。

寄存器间接寻址:指令中的地址码给出某一通用寄存器的编号,该寄存器中存放的是操作数的有效地址。例如,MOV A,@Ri(i=0或1),这条指令先寻址Ri寄存器,得到其中内容为操作数的地址,再访问该地址得到操作数。寄存器间接寻址方式结合了寄存器寻址和间接寻址的优点,既提高了访问速度,又扩大了寻址范围。

相对寻址:将程序计数器(PC)的内容加上指令格式中的形式地址,形成操作数的有效地址。相对寻址方式使得操作数的地址随着指令地址的变化而变化,但两者之间总是相差一个固定值,这对于实现程序的分支和循环非常有用。

基址寻址:将基址寄存器的内容加上指令格式中的位移量,形成操作数的有效地址。基址寻址方式通常用于将用户的逻辑地址转换为主存的物理地址,解决程序在主存中的定位问题。

变址寻址:将变址寄存器的内容与指令中给出的形式地址相加,形成操作数的有效地址。变址寻址方式最典型的用法是将指令中的形式地址作为基准地址,而变址寄存器的内容作为修改量,用于访问字符串、向量和数组等成批数据。

堆栈寻址:从规定的堆栈中取出操作数。堆栈是一种特殊的数据结构,遵循后进先出的原则,堆栈寻址方式通常用于实现子程序的调用和返回。

二、指令系统类型 

(一)按指令集长度分类

  1. 复杂指令系统(CISC)

    • 特点:指令长度可变,包含大量复杂的指令,指令格式和寻址方式多样化。
    • 优点:功能丰富,能够直接执行高级语言的某些操作,减少编译器的复杂性。
    • 缺点:指令复杂度高,执行时间长,功耗大,且大量复杂指令在实际中很少被使用,造成硬件资源的浪费。
    • 代表:x86指令集。
  2. 精简指令系统(RISC)

    • 特点:指令长度固定,指令格式简单,采用流水线技术,指令数量较少但每条指令的功能相对简单。
    • 优点:指令执行速度快,功耗低,易于实现高速缓存和流水线技术,适合用于高性能计算机和嵌入式系统。
    • 缺点:需要更多的指令来完成相同的任务,编译器和汇编语言的设计相对复杂。
    • 代表:MIPS、ARM、LoongArch等。
  3. 超长指令系统(VLIW)

    • 特点:本质是多条同时执行指令的组合,每条指令可以包含多个操作,指令长度非常长。
    • 优点:能够充分利用处理器的并行处理能力,提高指令的执行效率。
    • 缺点:编译器的设计非常复杂,需要精确地预测哪些指令可以并行执行,且对处理器的硬件设计有较高要求。
    • 应用:主要在一些高性能计算领域和特定应用中使用。

(二)按指令操作的数据类型分类

  1. 堆栈型指令

    • 特点:操作数都在栈顶,通过压栈和出栈操作进行数据的存取和运算。
    • 优点:指令格式简单,易于实现,适合用于解释性语言和某些嵌入式系统。
    • 缺点:运算速度相对较慢,因为需要频繁地进行栈操作。
  2. 累加器型指令

    • 特点:一个隐含操作数是累加器,另一个操作数在指令中指定,结果写回到累加器中。
    • 优点:简化了指令格式,减少了内存访问次数。
    • 缺点:累加器的使用限制了指令的并行性,且不适用于所有类型的运算。
  3. 寄存器型指令

    • 特点:操作数都来自寄存器,结果也存于寄存器中。寄存器型指令包括寄存器-存储器型和寄存器-寄存器型两种。
    • 优点:访问速度快,因为寄存器通常位于CPU内部,且能够充分利用处理器的并行处理能力。
    • 缺点:寄存器数量有限,寻址范围受限,需要编译器进行复杂的寄存器分配和优化。

(三)按指令的功能分类

  1. 数据传送类指令

    功能:实现数据在不同存储单元之间的传送,包括主存单元之间、主存和寄存器之间、寄存器和寄存器之间的数据传送。
  2. 算术/逻辑运算类指令

    功能:完成定点/浮点数的四则运算、求补等运算,以及逻辑运算、移位操作等。
  3. 程序控制类指令

    功能:改变程序的执行顺序,包括条件转移、无条件转移、循环控制等。
  4. 输入输出类指令

    功能:实现外设和主机之间、外围设备之间的信息交换。
  5. 其他指令

    功能:包括字符串处理指令、特权指令、程序状态字寄存器置位复位指令、测试指令、暂停指令等。这些指令用于实现特定的功能或满足特定的需求。

三、Flynn分类

(一)基本概念

指令流:指计算机在执行程序时,指令序列的流动。

数据流:指计算机在执行指令时,所需数据的流动。

(二)四种基本架构类型

  1. 单指令流单数据流(SISD, Single Instruction Single Data Stream)

    • 特点:传统的顺序处理计算机,其指令部件一次仅对一条指令进行译码,并仅对一个操作部件分配数据。
    • 示例:早期的个人计算机,如386、486等,以及某些单片机系统。
    • 应用:适用于简单的顺序执行任务,如基本的算术和逻辑运算。
  2. 单指令流多数据流(SIMD, Single Instruction Multiple Data Stream)

    • 特点:包含多个重复的运算处理单元,但仅存在唯一的指令部件。指令部件从存储器中取出指令,译码后发往所有运算处理单元,各运算处理单元按照同一指令流的要求处理各自不同的数据。
    • 优点:能够高效处理大量相同类型的数据,实现空间上的并行性。
    • 示例:图形处理器(GPU)、Intel的MMX或SSE指令集、AMD的3D Now!指令集。
    • 应用:适用于多媒体处理、图像处理、科学计算等领域。
  3. 多指令流单数据流(MISD, Multiple Instruction Stream Single Data Stream)

    • 特点:多个指令流处理单个数据流。然而,这种架构在实际应用中很少见,因为它并不高效。理论上,每个指令流可能对数据流执行不同的操作,但在实践中,很难找到一个实际的应用场景,其中这种处理方式会比单指令流或多指令流多数据流更有优势。
    • 现状:主要作为理论模型存在,没有投入到实际应用之中。
  4. 多指令流多数据流(MIMD, Multiple Instruction Stream Multiple Data Stream)

    • 特点:实现作业、任务、指令、数据各个级别全面并行执行的计算机系统。拥有多个处理机,每个处理机具有独立的程序,每个程序为相应的处理器生成一个指令流,并处理各自不同的数据。
    • 优点:能够充分利用处理器的并行处理能力,提高系统的整体性能。
    • 示例:高性能服务器、超级计算机、分布式计算机系统。
    • 应用:适用于大规模数据处理、高性能计算、云计算等领域。

(三)意义与应用

       Flynn分类法不仅有助于理解不同计算机架构的并行性特点和处理方式,还为计算机系统的设计和优化提供了指导。例如,在开发高性能计算机或嵌入式系统时,可以根据具体的应用需求选择合适的架构类型。同时,Flynn分类法也为计算机体系结构的研究和发展提供了重要的理论基础。

四、流水线技术

(一)基本原理

       流水线技术的基本原理是将一个重复的过程分解为若干个子过程,这些子过程在时间上重叠进行,前一个子过程为下一个子过程创造执行条件。在计算机系统中,流水线技术被用来优化指令的执行过程,将一条复杂的指令分解为多个简单的子任务,并由不同的功能部件并行处理,从而提高整体执行效率。

(二)分类

  1. 按处理级别分类

    • 部件级流水线:在处理较为复杂的运算时采用。
    • 指令级流水线:将一条指令的执行过程分为多个阶段,如取指令、译码、执行、写回结果等。
    • 处理器间级流水线:每个处理器完成其专门的任务。
  2. 按功能分类

    • 单功能流水线:只完成一种功能,如乘法或浮点运算等,多用于数字信号处理器(DSP)。
    • 多功能流水线:在不同情况下可完成不同功能。
  3. 按连接方式分类

    • 静态流水线:同一时间内,多功能结构只能按一种功能的连接方式工作。
    • 动态流水线:同一时间内,可以有多种功能的连接方式同时工作。
  4. 按处理对象分类

    • 标量流水线:处理一般数据。
    • 向量流水线:处理矢量数据。
  5. 按流水线形状分类

    • 线性流水线:指各功能模块顺序串行连接,无反馈回路。
    • 非线性流水线:带有反馈回路的流水线。

(三)关键步骤与实现方式

       以经典的奔腾处理器为例,其整数流水线通常分为四级:指令预取、译码、执行和写回结果。每一级都对应一个专门的功能部件,负责完成相应的子任务。当第一条指令在执行某一阶段时,第二条指令可以同时进入流水线的下一个阶段,以此类推,实现了指令的并行处理。

       流水线技术主要通过硬件电路来实现。在CPU中,通过设计多个并行工作的功能部件和相应的控制逻辑,来支持指令的并行处理。此外,软件层面的优化也是实现流水线技术的重要手段。编译器可以通过重新组织代码、优化指令序列等方式,来减少指令间的依赖关系,提高流水线的效率。

(四)性能指标

  1. 吞吐率:指的是计算机中的流水线在特定的时间内可以处理的任务或输出数据的结果的数量。流水线的吞吐率可以进一步分为最大吞吐率和实际吞吐率,它们主要和流水段的处理时间、缓存寄存器的延迟时间有关。
  2. 效率:表示流水线的设备利用率。在时空图上,流水线的效率定义为有效时间与总时间之比。
  3. 加速比:用S表示,若一个任务在单功能部件上顺序执行需n个时间单位,在m段流水线上执行需(m+n-1)个时间单位,则流水线对该任务的加速比为S=n/(m+n-1)。

(五)优势与挑战

  1. 提高执行速度:通过并行处理多条指令的不同阶段,流水线技术显著提高了计算机的执行速度。
  2. 资源利用率高:各个功能部件在同一时间内可以处理不同的指令子任务,从而提高了硬件资源的利用率。
  3. 简化设计复杂度:将复杂的指令分解为简单的子任务,有助于简化计算机体系结构的设计和实现。

       然而,流水线技术也面临着一些挑战,如资源冲突、数据冒险等问题。为了解决这些问题,设计者们采取了多种措施,如增加缓存、优化指令调度等,以确保流水线的顺畅运行。

(六)应用与影响

       流水线技术在现代计算机系统中得到了广泛应用,从个人电脑到大型服务器,从嵌入式系统到云计算平台,都可以看到流水线技术的身影。它显著提高了CPU的运算速度,使得计算机能够更快地处理数据。此外,流水线技术还促进了计算机硬件和软件的发展,为计算机性能的不断提升提供了有力支持。

 结语  

人生路上步步未知

正是这些铸就精彩

!!!

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

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

相关文章

【数据结构】_以SLTPushBack(尾插)为例理解单链表的二级指针传参

目录 1. 第一版代码 2. 第二版代码 3. 第三版代码 前文已介绍无头单向不循环链表的实现,详见下文: 【数据结构】_不带头非循环单向链表-CSDN博客 但对于部分方法如尾插、头插、任意位置前插入、任意位置前删除的相关实现,其形参均采用了…

【Samba】Ubuntu20.04 Windows 共享文件夹

【Samba】Ubuntu20.04 Windows 共享文件夹 前言整体思路检查 Ubuntu 端 和 Windows 网络通信是否正常创建共享文件夹安装并配置 Samba 服务器安装 Samba 服务器创建 Samba 用户编辑 Samba 配置文件重启 Samba 服务器 在 Windows 端 访问 Ubuntu 的共享文件夹 前言 本文基于 Ub…

Linux初识——基本指令(2)

本文将继续从上篇末尾讲起,讲解我们剩下的基本指令 一、剩余的基本指令 1、mv mv指令是move(移动)的缩写,其功能为:1.剪切文件、目录。2.重命名 先演示下重命名,假设我想把当前目录下的di34改成dir5 那…

Android - 通过Logcat Manager简单获取Android手机的Log

由于工作需要,经常需要获取Android手机的Log。 平常都是通过adb命令来获取,每次都要写命令。 偶然的一个机会,我从外网发现了一个工具 Logcat Manager,只需要通过简单的双击即可获取Android的Log,这里也分享一下。 目…

c++学习第十三天

创作过程中难免有不足,若您发现本文内容有误,恳请不吝赐教。 提示:以下是本篇文章正文内容,下面案例可供参考 一、vector 1.介绍 1. vector是表示可变大小数组的序列容器。 2. 就像数组一样,vector也采用的连续存储空…

「数学::质数」分解质因子 / LeetCode 2521(C++)

概述 由算数基本定理,我们知道任意一个大于1的自然数可以表示为一些质数的乘积: LeetCode 2521: 给你一个正整数数组 nums ,对 nums 所有元素求积之后,找出并返回乘积中 不同质因数 的数目。 注意: 质数 是…

docker-compose Zookeeper 集群搭建

文章目录 前言docker-compose Zookeeper 集群搭建1. Zookeeper下载2. 制作Dockerfile文件3. 构建镜像4. docker-compose 管理5. docker-compose构建/启动6. 验证6.1 docker ps6.2 使用 zkCli.sh 连接并验证集群 前言 如果您觉得有用的话,记得给博主点个赞&#xff0…

WIN11 UEFI漏洞被发现, 可以绕过安全启动机制

近日,一个新的UEFI漏洞被发现,可通过多个系统恢复工具传播,微软已经正式将该漏洞标记为追踪编号“CVE-2024-7344”。根据报告的说明,该漏洞能让攻击者绕过安全启动机制,并部署对操作系统隐形的引导工具包。 据TomsH…

R语言学习笔记之高效数据操作

一、概要 数据操作是R语言的一大优势,用户可以利用基本包或者拓展包在R语言中进行复杂的数据操作,包括排序、更新、分组汇总等。R数据操作包:data.table和tidyfst两个扩展包。 data.table是当前R中处理数据最快的工具,可以实现快…

【数据结构】 并查集 + 路径压缩与按秩合并 python

目录 前言模板朴素实现路径压缩按秩合并按树高为秩按节点数为秩 总结 前言 并查集的基本实现通常使用森林来表示不同的集合,每个集合用一棵树表示,树的每个节点有一个指向其父节点的指针。 如果一个节点是它自己的父节点,那么它就是该集合的代…

低代码系统-产品架构案例介绍、得帆云(八)

产品名称 得帆云DeCode低代码平台-私有化 得帆云DeMDM主数据管理平台 得帆云DeCode低代码平台-公有云 得帆云DePortal企业门户 得帆云DeFusion融合集成平台 得帆云DeHoop数据中台 名词 概念 云原生 指自己搭建的运维平台,区别于阿里云、腾讯云 Dehoop 指…

【PyTorch】5.张量索引操作

目录 1. 简单行、列索引 2. 列表索引 3. 范围索引 4. 布尔索引 5. 多维索引 个人主页:Icomi 在深度学习蓬勃发展的当下,PyTorch 是不可或缺的工具。它作为强大的深度学习框架,为构建和训练神经网络提供了高效且灵活的平台。神经网络作为…

基于微信小程序高校课堂教学管理系统 课堂管理系统微信小程序(源码+文档)

目录 一.研究目的 二.需求分析 三.数据库设计 四.系统页面展示 五.免费源码获取 一.研究目的 困扰管理层的许多问题当中,高校课堂教学管理也是不敢忽视的一块。但是管理好高校课堂教学又面临很多麻烦需要解决,如何在工作琐碎,记录繁多的情况下将高校课堂教学的当前情况反…

论文阅读笔记:VMamba: Visual State Space Model

论文阅读笔记:VMamba: Visual State Space Model 1 背景2 创新点3 方法4 模块4.1 2D选择性扫描模块(SS2D)4.2 加速VMamba 5 效果5.1 和SOTA方法对比5.2 SS2D和自注意力5.3 有效感受野5.4 扫描模式 论文:https://arxiv.org/pdf/240…

【文星索引】搜索引擎项目测试报告

目录 一、项目背景二、 项目功能2.1 数据收集与索引2.2 API搜索功能2.3 用户体验与界面设计2.4 性能优化与维护 三、测试报告3.1 功能测试3.2 界面测试3.3 性能测试3.4 兼容性测试3.5 自动化测试 四、测试总结4.1 功能测试方面4.2 性能测试方面4.3 用户界面测试方面 一、项目背…

DBO-高斯回归预测matlab

蜣螂优化算法(Dung Beetle Optimizer, DBO)是一种新型的群智能优化算法,在2022年底提出,主要是受蜣螂的的滚球、跳舞、觅食、偷窃和繁殖行为的启发。 本次研究使用的是 Excel 格式的股票预测数据。数据集按照 8:1:1 的比例&#x…

java后端之事务管理

Transactional注解:作用于业务层的方法、类、接口上,将当前方法交给spring进行事务管理,执行前开启事务,成功执行则提交事务,执行异常回滚事务 spring事务管理日志: 默认情况下,只有出现Runti…

【嵌入式】总结——Linux驱动开发(三)

鸽了半年,几乎全忘了,幸亏前面还有两篇总结。出于快速体验嵌入式linux的目的,本篇与前两篇一样,重点在于使用、快速体验,uboot、linux、根文件系统不作深入理解,能用就行。 重新梳理一下脉络,本…

RabbitMQ 多种安装模式

文章目录 前言一、Windows 安装 RabbitMq1、版本关系2、Erlang2.1、下载安装 Erlang 23.12.2、配置 Erlang 环境变量 3、RabbitMQ3.1、下载安装 RabbitMQ 3.8.93.2、环境变量3.3、启动RabbitMQ 管理插件3.3、RabbitMQ3.4、注意事项 二、安装docker1、更新系统包:2、…

使用python-docx包进行多文件word文字、字符批量替换

1、首先下载pycharm。 2、改为中文。 3、安装python-docx包。 搜索包名字,安装。 4、新建py文件,写程序。 from docx import Documentdef replace1(array1):# 替换词典(标签值按实际情况修改)dic {替换词1: array1[0], 替换…