深入理解计算机系统(3.4)------算术和逻辑操作

  上一篇博客  我们介绍了几种数据传送指令,包括MOV,MOVS,MOVZ,PUSH和POP等,理解起来也不算难。本篇博客我们来接着看汇编语言的算术与逻辑运算指令,算术无非就是加减乘除,而逻辑运算也就是与或非,移位等操作。下面这张图是汇编里面的算术和逻辑操作:

  上面除了 leal(加载有效地址)指令通常用来执行简单的算术操作,其余的指令都是标准的一元或者二元操作,下面我们分别来介绍这几个指令操作。

1、leal 指令

  leal 指令也称为加载有效地址(load effective address)指令,它实际上是 movl 指令的变形。它的指令形式是从存储器读数据到寄存器,但实际上它根本没有引用存储器。

  它的第一个操作数看上去是一个存储器引用,但该指令并不是从指定的位置读取数据,而是将有效地址写入到目的操作数,类似于 C 语言的取地址操作符“&”。另外就是作普通的算术运算。

  leal  立即数,寄存器

  这类指令就是将立即数装载至寄存器,比如 leal $0x01,%eax  这种情况下 和 movl $0x01,%eax 的效果是等价的

leal  地址,寄存器

  leal指令的作用是将地址加载到寄存器,对于leal S,D而言,就是实现了 &S –> D 的功能

leal   S, D    结果是&S -> D

  movl  S,D   结果是S -> D

通用的操作我们就不讲了,这里讲一下取地址操作,比如对于leal 4(%edx,%edx,4),%eax这条指令来讲,我们假设%edx寄存器的值为x的话,那么这条指令的作用就是将 4 + x + 4x = 5x + 4赋给%eax寄存器。它和mov指令的区别就在于,假设是movl 4(%edx,%edx,4),%eax这个指令,它的作用是将内存地址为5x+4的内存区域的值赋给%eax寄存器,而leal指令只是将5x+4这个地址赋给目的操作数%eax而已,它并不对存储器进行引用的值的计算。

   为了更好的表示这条指令的效果,这里简单的画个图来表示这一过程。我们假设下图是执行指令之前,寄存器和存储器的状态。

下面的几幅图均引用:http://www.cnblogs.com/zuoxiaolong/p/computer16.html 个人觉得解释的非常形象。

  可以看到,此时在存储器中,地址为5x+4的区域的值为1000。那么此时若是进行movl 4(%edx,%edx,4),%eax操作,很显然,%eax的值应该为1000,也就是下图。

  但是如果进行leal 4(%edx,%edx,4),%eax操作的话,%eax的值就不是1000了,因为leal指令不会去取存储器当中的值,因此寄存器%eax的值应该是5x+4。

  试想一下,倘若在地址为5x+4的位置存储的是变量i,那么其实这条指令就相当于&i操作,这也就是C语言当中的&取地址操作的汇编级做法。

  此外,它还可以简单的描述普通的算术操作,比如假如寄存器 %edx 的值为 x,那么指令 leal 7 (%edx,%edx,4),%eax。 这表示的意思是设置寄存器 %eax 的值为 7+x+4x=5x+7。这里的leal指令根本与有效地址无关,但是需要注意的是目的操作数必须是寄存器。

2、INC、DEC、NEG、NOT 指令 

  这四个指令的格式如下:

  这四个指令都是一元操作,即它们都只有一个操作数,即是源也是目的。这个操作数可以是寄存器,也可以是存储器。

  比如: incl (%esp)  会使栈顶的 4 字节元素加 1。可以联想到 C 语言的自增(++)或者自减(--)

3、ADD、SUB、IMUL、XOR、OR、AND 指令

  这一组指令格式如下:

  它们都是二元操作,其中第二个操作数即是源又是目的,我们可以联想到 C 语言的 x += y。

  第一个操作数可以是立即数、寄存器或存储器,第二个操作数可以是寄存器或存储器位置。不过和 movl 指令一样,两个操作数不能同时是存储器位置。

4、SAL、SHL、SAR、SHR 指令

  移位操作,指令格式如下:

  第一个操作数是移位量,SAL 和 SHL 都是左移指令,效果是一样的,移动几位,右边补上几位0;右移指令不同,算术右移 SAR 是补上符号位,即右边的第一位;逻辑右移 SHR 是补上 0 。

  移位的目的操作数可以是一个寄存器或是一个存储器位置。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏青玉伏案

算法与数据结构(十二) 散列(哈希)表的创建与查找(Swift版)

散列表又称为哈希表(Hash Table), 是为了方便查找而生的数据结构。关于散列的表的解释,我想引用维基百科上的解释,如下所示: 散列表(Hash tab...

19610
来自专栏java学习

Java每日一练(2017/6/4)

题目要求 删除目录功能: 客户任意输入一个路径,若路径格式正确则输出该路径下的所有文件夹名称 并提示“是否要删除以下的文件夹(注意:文件夹下面的所有内容...

2655
来自专栏雨尘分享

3. __block  __weak  __strong   这都是做什么的

1703
来自专栏和蔼的张星的图像处理专栏

638. 字符同构哈希映射

给定两个字符串 s 和 t ,确定它们是否是同构的。 两个字符串是同构的如果 s 中的字符可以被替换得到 t。 所有出现的字符必须用另一个字符代替,同时保留...

433
来自专栏海纳周报

JVM杂谈之JIT

JIT技术是JVM中最重要的核心模块之一。因为不断有朋友问起,Java到底是怎么运行的?既然Hotspot是C++写的,那Java是不是可以说运行在C++之上呢...

34812
来自专栏Golang语言社区

实效go编程--2

Go函数的返回值或结果“形参”可被命名,并作为常规变量使用,就像传入的形参一样。 命名后,一旦该函数开始执行,它们就会被初始化为与其类型相应的零值; 若该函数执...

3237
来自专栏小樱的经验随笔

用php做个简单的日历

存档: index.php 1 <html> 2 <head> 3 <title>日历</title> 4 <s...

2665
来自专栏Java技术分享

分布式唯一ID生成器Twitter 的 Snowflake idworker java版本

import java.lang.management.ManagementFactory; import java.net.InetAddress; impo...

3399
来自专栏mukekeheart的iOS之旅

Java基础整理(1)

1、源代码的文件名必须与公共类(public)的类名一致,而且一个源代码文件中最多只能有一个公共类(public) ---- 2、注释: 3种 行注释  以双斜...

2197
来自专栏吴伟祥

为什么计算机最小的存储单位是字节?而最小到的传输单位是bit?

数据存储是以“字节”(Byte)为单位,数据传输是以大多是以“位”(bit,又名“比特”)为单位,一个位就代表一个0或1(即二进制),每8个位(bit,简写为b...

542

扫码关注云+社区