7.5  扩展加法和减法 扩展精度的假发和减法是指任意尺寸大小数字的加法和减法.例如要求你写一个C++程序,把两个1024位的整数相加,解决方案可不是那么简单!但在汇编语言中,ADC(带进位加)指令和SBB(带进位减)指令非常适合于解决此类问题. 7.5.1  ADC指令 ADC(AddWithCarry)指令把源操作数.目的操作数以及进位标志相加.指令格式与MOV指令是一样的: ADC  reg ,reg ADC  mem ,reg ADC  reg ,mem ADC  mem ,imm AD…
第七章 整数算术指令 7.1 简介 每种汇编语言都有进行操作数移位的指令,移位和循环移位指令在控制硬件设备.加密数据,以及实现高速的图形操作时特别有用.本章讲述如何进行移位和循环移位操作以及如何使用移位操作进行高效的乘法和出发运算. 接下来,我们将探究IA-32指令集中的乘法和出发指令,Intel根据运算是有符号还是无符号的对乘法和出发进行分类.本章还讲述如何把C++中的数学表达式翻译成汇编语言.编译器把符合表达式分解翻译成一系列机器指令,模拟编译器有助于理解其工作机制,同时也有助于更好地对汇编…
7.3  移位和循环移位的应用 7.3.1  多双字移位 要对扩展精度整数(长整数)进行移位操作,可把它划分为字节数组.字数组或双字数组,然后再对该数组进行移位操作.在内存中存储数字时通常采用的方式是最低字节在最低的地址位置上(小尾顺序).下面的步骤以一个双字节数组为例,说明了如何把这样的一个数组右移移位: ArraySize = 3 .data array DWORD ArraySize DUP(?) 1.把ESI的值设置为array的偏移. 2.把最高位置[ESI+8]处的双字右移一位,最低…
第八章 高级过程 8.1 简介 本章主要讲: 堆栈框架 变量作用域和生存期 对战参数的类型 通过传递值或者传递引用来传递参数 在堆栈上创建和初始化局部变量 递归 编写多模块程序 内存模型和语言关键字 注意关键词: 子过程=函数=方法(因不同语言导致名字不统一) 8.2堆栈框架(很重要) 堆栈框架(stack frame)也称活动记录(activation record),它是为传递的参数.子例程的返回地址.局部变量和保存的寄存器保留的堆栈空间.堆栈框架是按一下步骤创建的: 1.如果有传递的参数,…
由于绝大多数的国内程序员以前只接触过Intel格式的汇编语言,很少或几乎没有接触过AT&T汇编语言,虽然这些汇编代码都是Intel风格的.但在Unix和Linux系统中,更多采用的还是AT&T格式,两者在语法格式上有着很大的不同,其实完全可以使用原来汇编的思路解决问题,只要掌握下面两者的不同: 一.在AT&T汇编格式中,寄存器名要加上' %'作为前缀:而在Intel汇编格式中,寄存器名不需要加前缀.例如: AT&T格式 Intel格式 pushl %eax push eax…
转自AT&T 和 Intel 汇编语法的主要区别 作为一个爱折腾的大好青年,补番之余还要补一些 Linux 下的基础,比如 GDB 的正确使用方法.但无论是看 gdb 还是 gcc -S 里的汇编,感觉都不能一下子接受这种设定. 后来发现,虽然同为 x86 汇编,但语法也分两大流派:之前上学时学的 Intel 语法,以及流行于 Unix/Linux 平台上的 AT&T 语法. 首先,两者最让人纠结的区别就是源操作数.目标操作数的顺序.AT&T 语法先写源操作数,再写目标操作数:In…
GNU ARM汇编程序设计中,每行的语法格式如下: [<label>:] [<instruction | directive | pseudo-instruction>] @comment 如果语句太长,可以将一条语句分几行来书写,在行末用“\”表示换行.“\”后不能有任何字符,包含空格和制表符(Tab) 参数说明: label:为标号,可选,可以使用字母,数字,下划线:除局部标号外,必须以字母或下划线开头.标号必须以“:”号结尾.标号大小写敏感 instruction | dir…
一.MASM汇编器中的数据类型 二.Intel汇编中的立即数类型 三.定义有符号和无符号整数 四.小端序 内存中数据按照字节存储,一个4个字节无符号整数,其高位存储在低地址上,低位存储在高地址上. 比如0x12345678这个整数,在内存中按照内存地址从小往大排列是:0X78 0x56 0x34 0x12 五.汇编代码验证 INCLUDE Irvine32.inc includelib Irvine32.lib includelib kernel32.lib includelib user32.…
第一步: 安装虚拟机32位XP系统 + RadAsm软件 第二步:    下载<Intel汇编语言程序设计第5版>中相关的源代码以及库文件           http://kipirvine.com/asm/examples/index.htm 将IrvineExamplesVS2008下载下来之后,解压出来inc和lib文件分别放在RadAsm的目录中 注:如果找不到路径,编译错误会提示你的, C:\RadASM\Masm32\Bin\ML.EXE /c /coff /Cp /nologo…
3.4  定义数据 3.4.1  内部数据类型 MASM定义了多种内部数据类型,每种数据类型都描述了该模型的变量和表达式的取值集合.数据类型的基本特征是以数据位的数目量的大小:8,16,32,,48,64,80位.其他特征(如有符号.指针.浮点等)主要是为了方便程序员记忆变量中存储的数据的类型.例如,声明为DOWRD变量逻辑上存储的是一个32位整数.一个32位的浮点数或一个32位的指针.MASM汇编器默认情况下是大小写不敏感的,因此伪指令如DWORD可写成dword,Dword.dWord等大小…