26考研 | 王道 | 计算机组成原理 | 四、指令系统

news2025/6/6 18:34:32

26考研 | 王道 | 计算机组成原理 | 四、指令系统

文章目录

  • 26考研 | 王道 | 计算机组成原理 | 四、指令系统
    • 1.指令系统
      • 0.指令集体系结构
      • 1. 指令格式
        • 1.按地址码数目不同来分
        • 2.指令-按指令长度分类
        • 3.指令-按操作码长度分类
        • 4.指令-按操作类型分类
      • 2. 扩展操作码指令格式
    • 2.指令的寻址方式
        • 1.顺序寻址(PC)+“1”–>PC
        • 2.跳跃寻址:由转移指令指出
      • 2. 数据寻址
        • 1.常见寻址方式
        • 2. 数据寻址–偏移寻址
        • 3. 数据寻址–堆栈寻址
    • 3.程序的机器级代码表示
      • 1. 高级语言与机器级代码之间的对应
      • 2. 常用的X86汇编语言指令
      • 3. ATu0026T格式和intel格式
      • 4. 选择语句的机器级表示
      • 5. 循环语句机器级表示
      • 6.函数调用的机器级表示
        • 1.call和ret指令
        • 2.如何访问栈帧
        • 3.如何切换栈帧
          • 进入函数
          • 函数返回
          • ret指令
        • 4.如何传递参数和返回值
    • 4. CISC和RISC

1.指令系统

0.指令集体系结构

image-20250604151625968

image-20250604151658241

image-20250604160149038

1. 指令格式

image-20250604103803885

image-20250604102736829

image-20250604102809082

1.按地址码数目不同来分

image-20250604103351242

image-20250604103008235

image-20250604103144391

image-20250604103226162

image-20250604103330396

2.指令-按指令长度分类

image-20250604103531737
机器字长和存储字长固定不变。

3.指令-按操作码长度分类

image-20250604103627413

4.指令-按操作类型分类

image-20250604103746769

程序控制类指令除了上述还有循环指令

2. 扩展操作码指令格式

image-20250604103902998

image-20250604104021670

image-20250604104137826

image-20250604104541253

image-20250604104605328

2.指令的寻址方式

###1. 指令寻址

image-20250604105529082

1.顺序寻址(PC)+“1”–>PC

image-20250604104945292
image-20250604105027197
image-20250604105224901

图中的指令字长是变化的,不是右边的16bit,所以才会每次读入一个字

2.跳跃寻址:由转移指令指出

image-20250604105518477
本节回顾

  1. 转移指令是通过修改PC实现的
  2. 程序计数器PC:存放下一条指令所在单元的地址
  3. 累加器ACC:用来存放操作数或运算结果
  4. 指令寄存器IR:临时放置从内存里面取得的程序指令的寄存器,用于存放当前从主存储器读出的正在执行的一条指令。
  5. 地址寄存器MAR:用来保存当前CPU所访问的内存单元的地址。

2. 数据寻址

image-20250604105811906

在这里插入图片描述

在这里插入图片描述

1.常见寻址方式

image-20250604110946756

取指令也需要一次访存(如果指令字长等于存储字长的话)

直接寻址

在这里插入图片描述

间接寻址

在这里插入图片描述

寄存器寻址

在这里插入图片描述

寄存器间接寻址

在这里插入图片描述

隐含寻址

在这里插入图片描述

立即寻址

在这里插入图片描述

2. 数据寻址–偏移寻址

image-20250604121951781

image-20250604115845766

基址寻址

在这里插入图片描述

image-20250604120311361

在这里插入图片描述

变址寻址

image-20250604120510270
image-20250604120626031

image-20250604120842407

其实IX的值就是个偏移量

在这里插入图片描述

基址&变址复合寻址

image-20250604121114645

相对寻址

在这里插入图片描述
image-20250604121517124

等到取指令取完第M+3条指令之后,PC值就会变为M+4,而不是M+3,所以相对寻址(跳转指令)就得按照PC=M+4来算,也就是补码表示的-4
在这里插入图片描述

基址寻址中程序浮动指的是整段程序在内存里的浮动,相对寻址中程序浮动指的是一段代码在程序内部的浮动。

本节回顾
在这里插入图片描述

硬件如何实现数的“比较”

image-20250604122205585
注:无条件转移指令jmp2,就不会管PSW的各种标志位。PC=2

3. 数据寻址–堆栈寻址

image-20250604122537785
在这里插入图片描述

image-20250604122644104

硬堆栈压入和弹出都不需要访存,而软堆栈不管压入还是弹出都需要一次访存,因为软堆栈是在主存中划分出来了一部分内容作为堆栈(也是函数调用时候保存信息的哪个堆栈)

image-20250604122901347
在这里插入图片描述

3.程序的机器级代码表示

1. 高级语言与机器级代码之间的对应

image-20250604203947053

X86汇编语言指令基础

在这里插入图片描述

以MOV指令为例

在这里插入图片描述

X86架构CPU,有哪些寄存器?

在这里插入图片描述

通用寄存器另外两种表示方式

在这里插入图片描述

####📊 通用寄存器功能概览

寄存器主要用途细分功能典型指令示例
AX累加器(核心运算)乘除运算、I/O操作、数据中转MULDIVINOUT
BX基址寄存器(内存寻址)存储偏移地址、数组/结构体访问MOV AX, [BX]LEA
CX计数器(循环/字符串控制)循环次数计数、字符串操作重复控制LOOPREP MOVSB
DX数据寄存器(I/O及高精度运算)I/O端口寻址、乘除法辅助、大数存储IN AX, DXMUL DX

在这里插入图片描述

更多例子
在这里插入图片描述

总结

在这里插入图片描述

2. 常用的X86汇编语言指令

image-20250604205159121

常见的算数运算指令

在这里插入图片描述

destination:目的地(d目的操作数)

source:来源地(s源操作数)

目的操作数d不可以是常量,可以来是寄存器或者主存

而s三者都可以

在进行除法运算之前,需要把被除数位扩展,如32bit/32bit要变成64b/32b,存放64位的被除数需要两个寄存器,edx:eax,高32位存放在edx,低32位存放在eax

在这里插入图片描述

X86汇编语言当中不允许两个操作数同时来源于主存。

在这里插入图片描述

3. ATu0026T格式和intel格式

在这里插入图片描述

在这里插入图片描述

4. 选择语句的机器级表示

程序默认是顺序执行的

程序中的选择语句(分支结构)

在这里插入图片描述

无条件转移指令–jmp

在这里插入图片描述

在这里插入图片描述

无条件转移指令,类似于c语言里的goto语句

无条件转移指令无法实现if,else语句,因为不需要任何条件就可以跳转

条件转移指令–jxxx

在这里插入图片描述

示例:选择语句的机器级表示

在这里插入图片描述

在这里插入图片描述

扩展:cmp指令的底层原理

在这里插入图片描述

5. 循环语句机器级表示

用条件转移指令实现循环

在这里插入图片描述

在这里插入图片描述

用loop指令实现循环

在这里插入图片描述

6.函数调用的机器级表示

image-20250604224103342

1.call和ret指令

image-20250604212515266

image-20250604212542835

image-20250604212634031

image-20250604212740643

image-20250604212830826

image-20250604212859170

2.如何访问栈帧

image-20250604213856167

image-20250604213023338

image-20250604213121590

image-20250604213210388

image-20250604213415337

image-20250604213334867

image-20250604213621791

image-20250604213647783

image-20250604213817354

3.如何切换栈帧

image-20250604222414167

进入函数

image-20250604213956495

image-20250604221727855

通过这两条命令保存上一层函数的栈帧地址,并设置当前函数的栈帧地址

image-20250604221852468

enter是零地址指令,直接等价于那两条命令

函数返回

执行那两条指令前是这样的

image-20250604222010270

执行第一条指令后,也就是让esp和ebp指向同一个位置

image-20250604222127950

执行第二条指令后,就返回了上一层函数调用

image-20250604222202678

这两条等价于leave

image-20250604222254605

ret指令

image-20250604222322658

image-20250604222545695

4.如何传递参数和返回值

image-20250604223858250

image-20250604222658556

image-20250604223210778

image-20250604223302078

如果用来保存 被调用函数的返回值 的寄存器原来有数据,那就得压栈,然后去保存返回值,等把返回值读出来以后再回复原来的数据

image-20250604223914089

前两句代码执行:相当于enter

image-20250604224303382

执行sub指令,相当于划分了一片属于自己的空间,即图中绿色部分

image-20250604224338087

执行接下来两句,作用是初始化变量temp1和temp2

image-20250604224500101

接下来四句指令都是给下层函数add传递参数,需要倒腾一遍,先把temp1放到寄存器,再从寄存器放回主存的对应地址(不从主存直接写到主存是因为汇编的源操作数和目的操作数不可以同时是主存)

image-20250604224611197

执行call指令,然后就是惯例执行add的前两行,这是保存上一层函数的信息

image-20250604224734229

通过ebp访问上层函数保存的本层函数要用的参数,保存到寄存器中

image-20250604224905591

执行add

image-20250604225019156

执行leave

image-20250604225039794

执行ret

image-20250604225116719

通过eax寄存器使用返回值

image-20250604225136280

image-20250604225230574

再次使用eax给再上一层函数返回值

image-20250604225308781

之后就是leave和ret了

4. CISC和RISC

image-20250605094538215

image-20250605094604517

image-20250605093824275

有的复杂指令用硬件实现困难,那就把组成复杂指令的一些简单的指令存储起来(微程序),完成这个复杂指令

比如矩阵乘就可以由剩下的整数加减乘和矩阵加减来完成

image-20250605094218985

image-20250605094457538

image-20250605094508917

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

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

相关文章

在 Windows 系统安装 Git

前往官网下载Git - Downloads 目录 一、下载安装包 二、安装 Git 三、安装完成 四、验证安装 五、问题解决 解决步骤 一、下载安装包 点击页面右侧 “Download for Windows” 按钮。 点击页面最上方 “Click here to download” ,下载 Git for Windows/x64 …

基于InternLM的情感调节大师FunGPT

基于书生系列大模型,社区用户不断创造出令人耳目一新的项目,从灵感萌发到落地实践,每一个都充满智慧与价值。“与书生共创”将陆续推出一系列文章,分享这些项目背后的故事与经验。欢迎订阅并积极投稿,一起分享经验与成…

【性能调优系列】深入解析火焰图:从基础阅读到性能优化实战

博客目录 一、火焰图基础:结构与阅读方法二、深入分析火焰图:关键观察点与性能瓶颈识别1. 识别最宽的函数块2. HTTP 请求处理分析3. 数据库操作分析4. 业务逻辑分析 三、性能优化实战:从火焰图到解决方案1. 线程池性能优化2. 数据库访问优化3…

Docker 与容器技术的未来:从 OCI 标准到 eBPF 的演进

Docker 的出现无疑是云计算发展史上的一个里程碑。它以其直观的打包、分发和运行方式,极大地简化了应用程序的部署和管理,从而推动了微服务架构和 DevOps 文化的普及。然而,容器技术的未来并非仅仅局限于 Docker,它正朝着更深层次的标准化和更底层的操作系统内核创新方向演…

PLC远程控制网关支持多塘口水环境数据边缘计算与远程安全传输的配置指南

一、项目背景 渔业养殖是关系到我国食物安全和海洋经济发展的重要产业,随着科技的不断进步,传统的养殖模式面临着诸多挑战,如养殖环境复杂、水质变化难以实时监测、设备运行状态不稳定等,这些问题不仅增加了养殖成本,还…

C++11 中 final 和 override 从入门到精通

文章目录 一、引言二、final 关键字2.1 final 关键字的基本概念2.2 final 关键字的语法2.3 final 关键字的使用示例2.3.1 防止类被继承2.3.2 防止虚函数被重写 2.4 final 关键字的使用场景2.5 final 关键字的注意事项 三、override 关键字3.1 override 关键字的基本概念3.2 ove…

大数据-275 Spark MLib - 基础介绍 机器学习算法 集成学习 随机森林 Bagging Boosting

点一下关注吧!!!非常感谢!!持续更新!!! 大模型篇章已经开始! 目前已经更新到了第 22 篇:大语言模型 22 - MCP 自动操作 FigmaCursor 自动设计原型 Java篇开…

git互联GitHub 使用教程

一、下载git Git 公司 右键 git config --global user.name "name" git config --global user.email "email" ssh-keygen -t rsa -C email :生成的ssh密钥需要到github 网站中保存ssh 二、GitHub新建repository 三、本地git互联GitHub 找…

SpringBoot+Mysql实现的停车场收费小程序系统+文档

💗博主介绍💗:✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌ 温馨提示:文末有 CSDN 平台官方提供的老师 Wechat / QQ 名片 :) Java精品实战案例《700套》 2025最新毕业设计选题推荐…

面向对象进阶 | 深入探究 Java 静态成员与继承体系

个人主页 文章专栏 文章目录 个人主页文章专栏 一、static(静态)1.static 静态变量代码展示内存图 2.static 静态方法工具类:练习: 3.static注意事项4.重新认识main方法 二、继承1.继承概述2.继承的特点3.子类到底能继承父类中的…

人脸识别技术成为时代需求,视频智能分析网关视频监控系统中AI算法的应用

一、应用背景:时代需求与技术革新的双重驱动​ 1)传统安防系统的困境​:传统监控系统依赖人工逐帧筛查海量视频,在人流密集场所极易漏检,且缺乏实时锁定和主动预警能力,面对突发安全事件响应迟缓。​ 2&a…

pc端小卡片功能-原生JavaScript金融信息与节日日历

代码如下 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>金融信息与节日日历</title><…

Go语言学习-->第一个go程序--hello world!

Go语言学习–&#xff1e;第一个go程序–hello world! 1 写代码前的准备 1 创建编写代码的文件夹 2 使用vscode打开3 项目初始化 **go mod init*&#xff08;初始化一个go mod&#xff09;Go Module 是 Go 1.11 版本引入的官方依赖管理系统&#xff0c;用于替代传统的 GOPATH…

高雄市12岁以下身心障碍儿童口腔保健合作院所名单数据集

描述&#xff1a; 关键字&#xff1a;儿童、口腔、保健、院所、名单 字段特征&#xff1a;序号、院所分级、合作医疗院所、市话、地址 语言&#xff1a;繁体 行数/数量&#xff1a;129行&#xff0c;5列 数据量 &#xff1a;7.27KB 格式&#xff1a;CSV、JSON、XML 目录…

破局新能源消纳难题!安科瑞智慧能源平台助力10KV配电网重构未来

一、政策驱动&#xff1a;新型配电网迎来 “智慧化” 刚需 随着分布式光伏、工商业储能、电动汽车充电桩等新型电力设施大规模并网&#xff0c;传统 10kV 配电网正面临 “高渗透、强波动、多交互” 的运行挑战。2025 年 6 月 1 日正式实施的《配电网通用技术导则》&#xff08;…

TIA博途中的程序导出为PDF格式的具体方法示例

TIA博途中的程序导出为PDF格式的具体方法示例 如下图所示&#xff0c;选中想要导出为PDF的程序块&#xff0c;右击选择“打印”&#xff0c; 如下图所示&#xff0c;选择“导出为WPS PDF” 或者“Microsoft Print to PDF”&#xff0c; 如下图所示&#xff0c;设置文档布局相关…

【大模型:知识图谱】--4.neo4j数据库管理(cypher语法1)

使用neo4j的cypher语法对图数据库进行管理&#xff1b;官网地址&#xff1a;Create, start, and stop databases - Operations Manual 目录 1.neo4j--简介 1.1.Neo4j版本的标准数据库 1.2.默认数据库 1.3.每用户主数据库 1.4.system数据库 2.neo4j--数据库管理 2.1.命名…

数字化时代养老机构运营实训室建设方案:养老机构运营沙盘实训模块设计

在数字化浪潮席卷各行各业的当下&#xff0c;养老机构运营实训室建设方案中的养老机构运营沙盘实训模块设计&#xff0c;已成为培养专业养老运营人才的关键环节&#xff0c;它需紧密贴合时代需求&#xff0c;构建兼具前瞻性与实用性的实训体系。点击获取实训室建设方案 一、养…

自由开发者计划 004:创建一个苹果手机长截屏小程序

一. 背景 年初&#xff0c;一个漂亮姐姐突然问我&#xff0c;iphone这么多年一直没法长截屏&#xff0c;你们程序员就没个办法把这个硬伤补上吗&#xff1f; 虎躯一震&#xff0c;脑瓜子嗡嗡的&#xff0c;这么多年的iphone资深用户&#xff0c;最初也不是没有想过这个问题&am…

工作流引擎-18-开源审批流项目之 plumdo-work 工作流,表单,报表结合的多模块系统

工作流引擎系列 工作流引擎-00-流程引擎概览 工作流引擎-01-Activiti 是领先的轻量级、以 Java 为中心的开源 BPMN 引擎&#xff0c;支持现实世界的流程自动化需求 工作流引擎-02-BPM OA ERP 区别和联系 工作流引擎-03-聊一聊流程引擎 工作流引擎-04-流程引擎 activiti 优…