第3章“程序的机器级表示”:算术和逻辑操作

news2025/1/22 9:06:11

文章目录

  • 3.5 算术和逻辑操作
    • 3.5.1 加载有效地址
    • 3.5.2 一元和二元操作
    • 3.5.3 移位操作
    • 3.5.4 讨论
    • 3.5.5 特殊的算术操作

3.5 算术和逻辑操作

下图列出了一些双字整数操作,分为四类。
在这里插入图片描述
二元操作有两个操作数,而一元操作只有一个操作数。

描述这些操作数的符号与 3.4 节中使用的符号完全相同。除了 leal 以外,每条指令都有对应的对字(16位)和对字节操作的指令。把后缀“l” 换成 “w” 就是对字的操作,而换成 “b” 就是对字节的操作了。例如,addl 对应有 addwaddb

3.5.1 加载有效地址

加载有效地址(Load Effective Address)指令 leal 实际上是 movl 指令的变形。它的指令形式是从存储器读数据到寄存器,但实际上它根本就没引用存储器。 它的第一个操作数看上去是一个存储器引用,但该指令并不是从指定的位置读入数据,而是将有效地址写入到目的操作数(如寄存器)。

在图3.7 中用 C 的地址操作符 &S 来说明这种计算。这条指令可以用来为后面的存储器引用产生指针。另外,它还可以用来简洁地描述普通的算术操作。例如,如果寄存器 %edx 的值为 x,那么指令 leal 7(%edx, %edx, 4), %eax 将设置寄存器 %eax 的值为 5x+7。注意:目的操作数必须是一个寄存器。

3.5.2 一元和二元操作

第二类操作是一元操作,只有一个操作数,既作源,也作目的。这个操作数可以是一个寄存器,也可以是一个存储器位置。比如说,指令 incl (%esp) 会使栈顶元素加1。这种语法让人想起 C 中的加1运算符(++)和减1运算符(--)。

第三类操作是二元操作,第二个操作数既是源又是目的。这种语法让人联想到 C 中像 += 这样的赋值运算符。不过,要注意,源操作数是第一个,目的操作数是第二个,这是不可交换操作特有的。例如,指令 subl %eax, %edx 使寄存器 %edx 的值减去 %eax 中的值。第一个操作数可以是立即数、寄存器或是存储器位置。第二个操作数可以是寄存器或是存储器位置。不过,同 movl 指令一样,两个操作数不能同时都是存储器位置。

3.5.3 移位操作

最后一类是移位操作,先给出移位量,然后是待移位的值。可以进行算术和逻辑右移。移位量用单个字节编码,因为只允许进行 0 到 31位的移位。移位量可以是一个立即数,或者放在单字节寄存器元素 %cl 中。

如图3.7 所示,左移指令有两个名字:sallshll。两者的效果都一样,都是将右边填上0。右移指令不同,sarl 执行算术移位(填上符号位),而 shrl 执行逻辑移位(填上0)。

3.5.4 讨论

除了右移操作,所有的指令都不区分有符号和无符号操作数。对列出的所有指令来说,二进制补码运算和无符号运算有同样的位级行为。

下图给出了一个执行算术操作的函数示例,以及它的汇编代码。和前面一样,省略了栈的建立和完成部分。函数参数 x 、 y x、y xy z z z 分别存放在存储器中相对于寄存器 %ebp 中地址偏移8、12 和 16 的地方。
在这里插入图片描述

  • 指令3实现表达式 x + y x+y x+y,一个操作数 y y y 来自寄存器 %eax(由指令 1 取出),而另一个直接来自存储器。
  • 指令4和5执行计算 z ∗ 48 z*48 z48,首先使 leal 指令对伸缩化的变址寻址模式的操作数执行计算: ( z + 2 z ) = 3 z (z+2z)=3z (z+2z)=3z,然后将这个值左移 4 位,以计算 2 4 ∗ 3 z = 48 z 2^4 * 3z = 48z 243z=48zC 编译器常常用加法和移位指令来完成常数因子的乘法。
  • 指令6执行 AND 操作;
  • 指令7执行最后的乘法。
  • 指令8将返回值移到寄存器 %eax。

在上图3.8的汇编代码中,寄存器 %eax 中的值先后对应于程序值 y y y t 1 t1 t1 t 3 t3 t3 t 4 t4 t4(作为返回值)。通常,编译器产生的代码中,会用一个寄存器存放多个程序值,还会在寄存器之间传送程序值。

3.5.5 特殊的算术操作

下图描述的是支持产生两个 32 位数字的全 64 位乘积以及整数除法的指令。
在这里插入图片描述
图3.7中列出的 imull 指令称为 “双操作数” 乘法指令。它从两个 32 位操作数产生一个 32 位乘积。当将乘积截取为32位时,无符号乘和二进制补码乘的位级是一样的。

IA32 还提供了两个不同的“单操作数”乘法指令,以计算两个 32 位值的全 64 位乘积——一个是无符号数乘法(mull),而另一个是二进制补码乘法(imull)。这两条指令都要求一个参数必须在寄存器 %eax 中,而另一个是作为指令的源操作数给出的。然后乘积存放在寄存器 %edx(高32位)和 %eax(低32位)中。注意,虽然 imull 这个名字可以用于两个不同的乘法操作,但是汇编器能够通过计算操作数的数目,分辨出是想用哪条指令。

举个例子,假设有符号数 x x x y y y 存储在相对于 %ebp 偏移量为 8 和 12 的位置,希望将它们的全 64 位乘积作为 8 个字节存放在栈顶。代码如下:
在这里插入图片描述
注意将两个寄存器入栈的顺序,对小端法(little-endian)机器来说是对的,在这种机器中栈是向低地址方向增长的(也就是说,乘积的低位字节的地址比高位字节的地址小)。

前面的算术运算表(图3.7)没有列出除法或模(modulus)操作。单操作数除法类似于单操作数乘法。有符号除法指令 idivl 将寄存器 %edx(高32位)和 %eax (低32位)中的 64 位数作为被除数,除数是作为指令的操作数给出的。指令将商存储在寄存器 %eax 中,将余数存储在寄存器 %edx 中。cltd 指令可以用来根据寄存器 %eax 中存放的 32 位的值形成 64 位被除数,这条指令将 %eax 符号扩展到 %edx。

如下例子,假设有符号数 x x x y y y 存储在相对于 %ebp 偏移量为 8 和 12 的位置,想要将 x / y x/y x/y x % y x \%y x%y 存储到栈中。代码如下:

在这里插入图片描述
divl 指令执行无符号除法。通常会事先将寄存器 %edx 设置为 0。

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

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

相关文章

极光笔记 | EngageLab Push的多时区解决方案

01、引言 多时区问题一直是全球客户和终端用户面临的挑战之一。EngageLab Push 致力于解决这个问题,确保全球各地的终端用户可以平等地享受到同样的推送服务,同时让客户能够更好地管理不同时区的应用和对应的终端用户。 02、解决多时区问题的总体方案 1…

软件测试----软件开发模型

1、瀑布模型 (1)瀑布模型如下 (2)瀑布模型的缺点: 在瀑布模型中,测试是在编码结束后才介入,对软件开发流程前期质量是没有保障的 (3)采用瀑布模型的场景: …

31 KVM管理系统资源-管理虚拟内存NUMA

文章目录 31 KVM管理系统资源-管理虚拟内存NUMA31.1 NUMA简介31.2 配置Host-NUMA操作步骤 31.3 配置Guest-NUMA操作步骤 31 KVM管理系统资源-管理虚拟内存NUMA 31.1 NUMA简介 传统的多核运算使用SMP(Symmetric Multi-Processor)模式:将多个…

Flume系列:Flume 自定义Interceptor拦截器

目录 Apache Hadoop生态-目录汇总-持续更新 1:Interceptor拦截器的使用场景 2:Interceptor拦截器在采集流程中的位置 3:自定义Interceptor拦截器 pom.xml 拦截器java代码 打包上传 4:使用自定义的拦截器 方式一&#xff1…

Springboot +spring security,自定义认证和授权异常处理器

一.简介 在Spring Security中异常分为两种: AuthenticationException 认证异常AccessDeniedException 权限异常 我们先给大家演示下如何自定义异常处理器,然后再结合源码帮助大家进行分析 二.创建项目 如何创建一个SpringSecurity项目,前…

分布式锁和事务关系的细节

使用redssion在redis上以及结合自定义注解利用spring的环绕切面来实现分布式锁功能 代码示例 controller、service层 RequestMapping("insertNumber/{number}/{id}") public boolean insertNumber(PathVariable Long number,PathVariable Long id){return testSer…

rust 中protobuf生成与使用

首先创建一个项目proto 进入到这个文件夹中 创建我们的proto文件 初始化的项目结构是这个样子的 新建一个hello.proto文件内容如下 syntax "proto3";package hello;service Greeter {rpc SayHello (HelloRequest) returns (HelloReply) {} }message HelloRequest …

干货 | 师兄手把手教你如何踏上科研道路

Hello,大家好! 这里是壹脑云科研圈,我是喵君姐姐~ 今天,邀请到鲁小白,给大家分享一下他踏上科研道路的心路历程。 大家好,我是鲁小白,我真正进入科研的时间,研究生3年再…

【C++】类和对象——类的引入、类的访问限定符、类的作用域、类的实例化、类的储存、this指针的引出和特性

文章目录 1.类的引入2.类的访问限定符3.类的作用域4.类的实例化5.类的储存6.this指针6.1this指针的引出6.2this指针的特性 1.类的引入 C是在C的基础上加以扩展。 在C语言中,我们想要让一个类型含有多种成员变量,我们使用结构体;而在C中我们可…

Doris节点扩容及数据表

扩容和缩容 上篇文章简单讲了doris的安装,本章分享的是doris中fe和be节点的扩容缩容以及doris的数据表1、FE 扩容和缩容 使用 MySQL 登录客户端后,可以使用 sql 命令查看 FE 状态,目前就一台 FE mysql -h linux -P 9030 -uroot -p mysql&…

python+django乡村居民数据的可视化平台

本论文主要论述了如何使用Django框架开发一个乡村振兴数据的可视化平台 ,本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述乡村振兴数据的可视化平台的当前背景以…

拼多多二面,原来是我对自动化测试的理解太浅了

如果你入职一家新的公司,领导让你开展自动化测试,作为一个新人,你肯定会手忙脚乱,你会如何落地自动化测试呢? 01 什么是自动化 有很多人做了很长时间的自动化但却连自动化的概念都不清楚,这样的人也是很悲…

Android之 MVC到MVVM架构发展和封装

一 简介 1.1 软件架构发展趋势是解耦,即分离数据层和视图层,使得数据层专注于业务的数据和逻辑处理。从而提高代码的可读可编辑效率,提高团队协作能力,项目的生产能力,降低后期维护成本。 1.2 Android架构发展MVC -…

计算机组成原理实验四 微程序控制器实验报告

我班算是几乎最后一个做实验的班级了,报告参考了一些朋友提供的数据加上一些自己的主观拙见,本人水平有限加之制作仓促难免有错误,望大家批评指正。 4.1 微程序控制器实验 一、实验目的 (1) 掌握微程序控制器的组成原理。 (2) 掌握微程序的…

【蓝桥杯计算思维题】少儿编程 蓝桥杯青少组计算思维真题及详细解析第5套

少儿编程 蓝桥杯青少组计算思维真题及详细解析第5套 1、北京冬奥会经历 17( ),中国体育代表团收获的金牌数和奖牌数均创历史新高 A、年 B、月 C、天 D、小时 答案:C 考点分析:主要考查小朋友们对时事的了解,北京冬奥会总共经历了17天,所以答案C 2、下面图形的周长是…

Python系列模块之标准库json详解

感谢点赞和关注 ,每天进步一点点!加油! 目录 一、Json介绍 二、JSON 函数 2.1 json.dumps 2.2 json.loads 2.3 实战案例:钉钉消息发送 一、Json介绍 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。它使得人们…

2023年21个最佳的Ruby测试框架

作者 | Veethee Dixit 测试人员总是在寻找最好的自动化测试框架,它能提供丰富的功能,并且语法简单、兼容性好、执行速度快。如果你选择将Ruby与Selenium结合起来进行web测试,那么可能需要搜索基于Ruby的测试框架进行web应用程序测试。 Ruby…

【Python】函数式编程第二弹

知识目录 一、写在前面✨二、最小公倍数三、移除数字四、总结撒花😊 一、写在前面✨ 大家好!我是初心,希望我们一路走来能坚守初心! 今天跟大家分享的文章是 Python函数式编程第二弹,再次以两个简单的例子带大家更好…

selenium UI自动化中文件上传的两种方式

前言 文件上传是自动化中很常见的一个功能,那么对于文件上传你又有多少了解呢?请往下看 1、被测产品中文件上传的功能非常普遍,一般情况下需要将准备好的文件放在预定的路径下,然后在自动化测试的脚本中,去预置的路径…

国内可以免费使用的GPT

一、wetab新标签页 教程:https://diwlwltzssn.feishu.cn/docx/MnHhdvxATomBnMxfas2cm8wWnVd 装GPT界面:https://microsoftedge.microsoft.com/addons/detail/wetab%E5%85%8D%E8%B4%B9chatgpt%E6%96%B0%E6%A0%87%E7%AD%BE%E9%A1%B5/bpelnogcookhocnaokfp…