csapp笔记3.6节——控制(1)

news/2025/2/4 12:10:55/

本节解决了x86-64如何实现条件语句、循环语句和分支语句的问题

条件码

除了整数寄存器外,cpu还维护着一组单个位的条件码寄存器,用来描述最近的算数和逻辑运算的某些属性。可检测这些寄存器来执行条件分支指令。

CF(Carry Flag):进位标志。最近的算术或逻辑运算使得最高位产生了进位。可检查无符号数操作的溢出。

ZF(Zero Flag):零标志。最近的算术或逻辑运算结果为0。

SF(Sign Flag):符号标志。最近的算术或逻辑运算结果为负数。

OF(Overflow Flag):溢出标志。最近的算术或逻辑运算导致补码溢出——正溢出或负溢出。

这里指出,leaq不会改变任何条件码,因为是被用来进行地址计算的。对于逻辑操作,例如XOR,进位和溢出标志会设置为0。对于移位操作,进位标志将设置为最后一个被移出的位,溢出标志设为0。INC和DEC指令会设置溢出和零标志,但不会改变进位标志。

除了基本的算术和逻辑指令会设置条件码之外,还有两类指令(8,16,32,64位形式)会设置条件码。

CMP指令行为与SUB指令一致,只是不会改变目的寄存器。

TEST指令与AND指令一致,只是不会改变目的寄存器的值。

访问条件码

通常不会直接读取条件码。常用方法有三种:(1)根据条件码的某种组合,将一个字节设置为0或者1。(2)可以条件跳转到程序的某个其他的部分。(3)可以有条件的传输数据。

对于第一种情况,我们用SET这类指令设置某个字节为1或0。SET根据某些条件码的算术或逻辑组合,将寄存器的某个低位字节或某个一个字节的内存位置置为1或0。

下图是SET指令

需要注意SET指令在大小比较时有符号数和无符号数是不同的指令。

举个例子分析下

我们来分析setl(有符号小于)具体是在那几个条件码的何种组合下进行工作的

cmpq获得a - b,这里在运算时可能会有如下几种情况

(1)未溢出,这时OF(溢出标志位)为0,则a - b的结果小于0那么a < b,根据a - b的结果小于0,SF被设为1。

(2)溢出,OF = 1,cmpq的结果由两种情况:小于零,说明a - b > 0,只有这样才会使得a和b进行补码减法后负溢出;大于零,说明a - b < 0,只有这样才会使得a和b进行补码减法后正溢出。(等于零不会溢出)这就可以看出只有cmpq运算结果是正数才能说明a < b。于是SF = 0。

可以看出 OF和SF异或的结果是setl判断的标准,若异或结果为1,说明a < b,%al被设为1;否则为0。

SET指令会区分有符号值和无符号值,这在汇编语言中并不常见,大多数情况,有符号数和无符号数都使用一样的指令,因为许多算术运算对无符号数和补码都有一样的位级行为。部分情况需要使用不同的指令,例如,右移、除法、乘法。


http://www.ppmy.cn/news/1569224.html

相关文章

蓝桥杯真题——小秘密(省模拟赛)

目录 题目链接&#xff1a;6.小秘密 - 蓝桥云课 题目描述 输入描述 输出描述 输入输出样例 样例说明 思路 那具体的步骤应该是这样的&#xff1a; 那具体的代码实现应该如何处理呢&#xff1f; 解法一&#xff1a;求解环的个数 Java写法&#xff1a; C写法&#xf…

搜索与图论复习1

1深度优先遍历DFS 2宽度优先遍历BFS 3树与图的存储 4树与图的深度优先遍历 5树与图的宽度优先遍历 6拓扑排序 1DFS&#xff1a; #include<bits/stdc.h> using namespace std; const int N10; int n; int path[N]; bool st[N]; void dfs(int u){if(nu){for(int i0;…

图论——最小生成树的扩展应用

最小生成树相关原理 acwing1146.新的开始 假设存在一个“超级发电站” 在每一个矿井修发电站相当于从这个“超级发电站”到各个矿井连一条长度为 v [ i ] v[i] v[i]的边。 这样一来这就是一个最短路的模板题。 #include <iostream> #include <cstring> using na…

简易CPU设计入门:指令单元(二)

项目代码下载 请大家首先准备好本项目所用的源代码。如果已经下载了&#xff0c;那就不用重复下载了。如果还没有下载&#xff0c;那么&#xff0c;请大家点击下方链接&#xff0c;来了解下载本项目的CPU源代码的方法。 CSDN文章&#xff1a;下载本项目代码 上述链接为本项目…

理解红黑树

简介&#xff1a;红黑树是一种自平衡二叉查找树&#xff0c;由鲁道夫贝尔&#xff08;Rudolf Bayer&#xff09;在1972年发明&#xff0c;最初称为“对称二叉B树”。它的设计旨在解决普通二叉查找树在频繁插入和删除操作时可能退化为链表的问题&#xff0c;从而保持高效的查找、…

ubuntu18.04环境下,Zotero 中pdf translate划线后不翻译问题解决

问题&#xff1a; 如果使用fastgithub&#xff0c;在/etc/profile中设置全局代理&#xff0c;系统重启后会产生划线后不翻译的问题&#xff0c;包括所有翻译代理均不行。终端中取消fastgithub代理&#xff0c;也不行。 解决&#xff1a; 1&#xff09;不在/etc/profile中设置…

Safari常用快捷键

一、书签边栏 1、显示或隐藏书签边栏&#xff1a;Control-Command-1 2、选择下一个书签或文件夹&#xff1a;向上头键或向下头键 3、打开所选书签&#xff1a;空格键 4、打开所选文件夹&#xff1a;空格键或右箭头键 5、关闭所选文件夹&#xff1a;空格键或左箭头键 6、更…

网络工程师 (13)时间管理

一、定义与重要性 项目时间管理是指为确保项目按时完成而采取的一系列规划、安排和控制活动。它始于项目启动阶段&#xff0c;贯穿整个项目生命周期&#xff0c;直至项目结束。时间管理对于项目的成功至关重要&#xff0c;它有助于项目团队明确工作目标和时间节点&#xff0c;增…