汇编语言-在线第2周3
汇编实验10课程设计

汇编实验10课程设计一、课程目标知识目标:1. 学生能够理解汇编语言的基本概念,掌握汇编指令的使用方法。
2. 学生能够描述实验10涉及的寄存器、寻址方式和指令的功能。
3. 学生能够解释汇编程序中出现的符号、标签和伪指令的含义。
技能目标:1. 学生能够运用汇编语言编写简单的程序,实现基本的输入输出、运算和控制流程。
2. 学生能够使用调试工具对汇编程序进行调试,找出并修正程序中的错误。
3. 学生能够分析汇编程序的执行过程,理解计算机硬件与软件的交互原理。
情感态度价值观目标:1. 学生通过学习汇编实验,培养对计算机底层原理的兴趣和好奇心,激发进一步学习的动力。
2. 学生能够认识到编程语言的发展历程,了解汇编语言在计算机体系结构中的地位,增强对计算机科学的敬畏之心。
3. 学生在学习过程中,培养团队协作、问题解决和自主学习的能力,形成积极向上的学习态度。
课程性质:本课程为计算机科学与技术专业选修课,以实验和实践为主,结合理论知识,培养学生的实际操作能力。
学生特点:学生已具备一定的计算机硬件和软件基础知识,具有较强的逻辑思维能力和动手操作能力。
教学要求:教师应注重理论与实践相结合,关注学生的个体差异,鼓励学生积极参与实验,充分调动学生的主观能动性。
同时,将课程目标分解为具体的学习成果,以便在教学设计和评估中实现有效监控。
二、教学内容本课程教学内容主要包括以下几部分:1. 汇编语言基础知识回顾:引导学生复习寄存器、指令系统、寻址方式等相关知识,为实验10的学习打下基础。
2. 实验目的与要求:介绍实验10的目的,明确实验要求和预期成果,让学生了解实验的重要性和实践意义。
3. 实验内容:- 编写汇编程序,实现数据输入输出、运算和控制流程等功能;- 学习使用调试工具,对汇编程序进行调试和优化;- 分析汇编程序执行过程,理解计算机硬件与软件的交互原理。
4. 教材章节:参考教材第十章“汇编语言程序设计”相关内容,结合实验10的具体要求,组织教学内容。
汇编语言常用指令汇总持续更新

汇编语言常用指令汇总持续更新汇编语言常用指令汇总汇编语言是一种低级编程语言,用于与计算机硬件进行直接交互。
熟悉汇编语言的常用指令对于理解计算机底层原理和进行底层编程非常重要。
本文将对汇编语言常用指令进行汇总,并持续更新。
1. 数据传输指令:- MOV:用于将数据从一个位置复制到另一个位置。
- LXI:用于将双字节立即数加载到指定的寄存器对中。
- LDA:用于将累加器加载到内存地址中的数据。
- STA:用于将累加器中的数据存储到指定的内存地址中。
2. 算术运算指令:- ADD:用于将累加器的内容与给定的寄存器或内存位置中的数据相加。
- SUB:用于从累加器中减去给定的寄存器或内存位置中的数据。
- INR:用于将给定的寄存器或内存位置中的数据增加1。
- DCR:用于将给定的寄存器或内存位置中的数据减少1。
3. 逻辑运算指令:- AND:用于将累加器的内容与给定的寄存器或内存位置中的数据进行逻辑与操作。
- OR:用于将累加器的内容与给定的寄存器或内存位置中的数据进行逻辑或操作。
- XOR:用于将累加器的内容与给定的寄存器或内存位置中的数据进行逻辑异或操作。
- NOT:用于对累加器的内容进行逻辑非操作。
4. 控制指令:- JMP:用于无条件转移到指定的内存地址。
- JZ:在累加器为零时,转移到指定的内存地址。
- JC:在进位标志为1时,转移到指定的内存地址。
- CALL:用于调用子程序。
5. 栈操作指令:- PUSH:用于将给定的寄存器或数据压入栈中。
- POP:从栈中弹出数据并存储到给定的寄存器中。
6. 输入输出指令:- IN:从外部设备读取数据,并存储到累加器中。
- OUT:将累加器中的数据发送到外部设备。
以上仅是汇编语言中常用指令的一小部分,还有许多其他指令可用于执行更复杂的任务。
在实际的汇编语言程序中,这些指令通常会与标签、变量和宏指令一起使用。
总结:汇编语言常用指令汇总了数据传输、算术运算、逻辑运算、控制、栈操作和输入输出等方面的指令。
计算机接口技术课件 第三章 MCS-51单片机汇编语言与程序设计基础

例2:编制一段程序,要求在端口线 :编制一段程序,要求在端口线P1.0,P1.1上分别产生周期为 , 上分别产生周期为 200us和400us的方波.设单片机的外接频率为 的方波. 和 的方波 设单片机的外接频率为12MHz. . 分析:利用定时器产生方波,将定时器设置成为工作方式 , 分析:利用定时器产生方波,将定时器设置成为工作方式3,将寄 存器T0定时 定时100us,T1定时 定时200us,达到定时时间后引起中断,在中 存器 定时 , 定时 ,达到定时时间后引起中断, 断服务程序中各自将P1.0和P1.1引脚取反. 引脚取反. 断服务程序中各自将 和 引脚取反 定时器预设值的设置: 定时器预设值的设置: 单片机的晶体振荡频率为12MHz,计时器的计时频率为1MHz,机 单片机的晶体振荡频率为 ,计时器的计时频率为 , 器周期为1us. 定时 定时100us,因此寄存器 需要计数 需要计数100次 器周期为 . T0定时 ,因此寄存器T0需要计数 次 ,其预 置值为64H+1=9CH. T1定时 定时200us,因此寄存器 需要计数 需要计数200次 置值为 . 定时 ,因此寄存器T1需要计数 次 其预置值为C8H+1=38H. ,其预置值为 . 定时器T0,T1的工作方式设置: 的工作方式设置: 定时器 的工作方式设置 T0采用工作方式 ,因此 采用工作方式3,因此TMOD寄存器的值设置为 寄存器的值设置为#22H. 采用工作方式 寄存器的值设置为 . 定时器T0,T1的控制设置: 的控制设置: 定时器 的控制设置 打开T0, ;要求TCON寄存器的值设置为 寄存器的值设置为#50H. 打开 ,T1;要求 寄存器的值设置为 .
定义存储区域的大小. 6. DS —定义存储区域的大小. 定义存储区域的大小 例: ORG 0350H DS 3
第5章 汇编语言程序

Y
条件满足?
N
处理段
例5-5 设内部RAM30H,31H单元存放两个无符号数, 将大数存在31H,小数存于30H。 ORG 1000H START:CLR C MOV A,30H SUBB A,31H JC NEXT ;次序符合,返回 MOV A,30H ;交换 XCH A,31H MOV 30H,A NEXT: NOP SJMP $ END
$
5-3 分支程序
由条件转移指令构成程序判断框,形成程序分支结构。 5-3-1 单重分支程序 一个判断决策框,程序有两条出路。 两种分支结构: 例1 求R2中补码绝对值,正数不变, 影响条件 负数变补。
MOV A,R2 JNB ACC.7,NEXT;为正数? CPL A ;负数变补 INC A MOV R2,A NEXT:SJMP NEXT ;结束
五、对源程序进行交叉汇编得到机器代码; 反汇编 —— 分析现成产品的程序,要将二进制 的机器代码语言程序翻译成汇编语言源程序。
六、程序调试。
通过微计算机的串行口(或并行口)把机器代 码传送到用户样机(或在线仿真器)进行程序 的调试和运行。
5.1.3评价程序质量的标准
(1)程序的执行时间。 (2)程序所占用的内存字节数。 (3)程序的逻辑性、可读性。 (4)程序的兼容性、可扩展性。 (5)程序的可靠性。
方法二:采用除10H取余数将BCD拆开 ORG 1000H MOV A,20H; 2B 1T MOV B,#10H ; 3B 2T DIV AB ; 1B 4T ORL B,#30H ; 3B 2T MOV 22H,B ; 3B 2T ORL A,#30H; 2B 1T MOV 21H,A ; 2B 1T SJMP $ END;7条指令、16个内存字节、13个机器周期。
汇编语言基本指令详解

汇编语言基本指令详解在计算机科学和计算机工程领域,汇编语言是一种计算机底层编程语言,用于直接控制计算机硬件。
它是机器语言的文本形式,使用符号和助记符来代表机器指令,相对于高级编程语言来说更加底层。
汇编语言基本指令是使用汇编语言进行编程时必不可少的内容。
下面将详细介绍汇编语言中常用的基本指令。
1. 数据传送指令数据传送指令用于在寄存器之间传递数据,常见的指令有MOV、ADD、SUB、MUL等。
MOV指令用于将数据从一个位置传送到另一个位置,格式为MOV 目标操作数, 源操作数。
例如,MOV AX, BX可以将BX的值传送给AX。
ADD指令用于将两个操作数相加,并将结果保存到目标操作数中。
格式为ADD 目标操作数, 源操作数。
例如,ADD AX, BX可以将AX与BX的值相加,并将结果保存在AX中。
SUB指令用于将源操作数的值从目标操作数中减去,并将结果保存到目标操作数中。
格式为SUB 目标操作数, 源操作数。
例如,SUB AX, BX可以将BX的值从AX中减去,并将结果保存在AX中。
MUL指令用于将两个操作数相乘,并将结果保存到目标操作数中。
格式为MUL 目标操作数, 源操作数。
例如,MUL AX, BX可以将AX与BX的值相乘,并将结果保存在AX中。
2. 算术逻辑指令算术逻辑指令用于进行各种算术和逻辑运算,例如加法、减法、乘法、除法、与、或、非等。
ADD指令在前面已经提到,用于将两个操作数相加。
SUB指令在前面已经提到,用于将源操作数的值从目标操作数中减去。
MUL指令在前面已经提到,用于将两个操作数相乘。
DIV指令用于将目标操作数除以源操作数,并将商保存到目标操作数,余数保存在DX中。
格式为DIV 操作数。
例如,DIV BX可以将AX的值除以BX,并将商保存在AX中,余数保存在DX中。
AND指令用于对两个操作数进行按位与运算,并将结果保存到目标操作数中。
格式为AND 目标操作数, 源操作数。
例如,AND AX,BX可以将AX与BX的值按位与,并将结果保存在AX中。
汇编语言指令大全

AAA 未组合的十进制加法调整指令AAA(ASCII Adgust for Addition)格式: AAA功能: 对两个组合的十进制数相加运算(存在AL中)的结果进行调整,产生一个未组合的十进制数放在AX中. 说明:1. 组合的十进制数和未组合的十进制数:在计算中,十进制数可用四位二进制数编码,称为BCD码.当一个节(8位)中存放一位BCD码,且放在字节的低4位, 高4位为时称为未组合的BCD码.2. AAA的调整操作若(AL) and 0FH>9 或 AF=1,则调整如下:(AL)<--(AL)+6,(AH)<--(AH)+1,AF=1, CF<--AF,(AL)<--(AL) and 0FHAAD 未组合十进制数除法调整指令AAD(ASCII Adjust for Division)格式: AAD功能: 在除法指令前对AX中的两个未组合十进制数进行调整,以便能用DIV指令实现两个未组合的十进制数的除法运算,其结果为未组合的十进制数,商(在AL中)和余数(在AH中). 说明:1. AAD指令是在执行除法DIV之前使用的,以便得到二进制结果存于AL中,然后除以OPRD,得到的商在AL中,余数在AH中.2. 示例: MOV BL,5MOV AX,0308HAAD ;(AL)<--1EH+08H=26H,(AH)<--0 DIV BL ;商=07H-->(AL),余数=03H-->(AH).AAM 未组合十进制数乘法调整指令AAM(ASCII Adjust MULtiply)格式: AAM功能: 对两个未组合的十进制数相乘后存于AX中的结果进行调整,产生一个未组合的十进制数存在AL中. 说明:1. 实际上是两个未组合的十进制数字节相乘,一个0~9的数与另一个0~9的数相乘其积最大为81.为了得到正确的结果,应进行如下调整:乘积: (AH)<--(AL)/10(AL)<--(AL)MOD102. 本指令应跟在MUL指令后使用,乘积的两位十进制结果,高位放在AH中,低位放在AL中.AH内容是MUL指令的结果被10除的商,即(AL)/10,而最后的AL内容是乘积被10整除的余数(即个位数).AAS 未组合十进制减法调整指令 AAS(ASCII Adjust for Subtraction)格式: AAS功能: 对两个未组合十进制数相减后存于AL中的结果进行调整,调整后产生一个未组合的十进制数数且仍存于AL中. 说明:1. 本指令影响标志位CF及AF.2. 调整操作若(AL) and 0FH > 9 或 AF=1则(AL)<--(AL)-6,(AH)<--(AH)-1,CF<--AF,(AL)<--(AL) and 0FH,否则(AL)<--(AL) and 0FHADC 带进位加法指令 ADC(Addition Carry) 格式: ADC OPRD1,OPRD2功能: OPRD1<--OPRD1 + OPRD2 + CF 说明:1. OPRD1为任一通用寄存器或存储器操作数,可以是任意一个通用寄存器,而且还可以是任意一个存储器操作数. OPRD2为立即数,也可以是任意一个通用寄存器操作数.立即数只能用于源操作数.2. OPRD1和OPRD2均为寄存器是允许的,一个为寄存器而另一个为存储器也是允许的,但不允许两个都是存储器操作数.3. 加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.4. 该指令对标志位的影响同ADD指令.ADD 加法指令 ADD(Addition)格式: ADD OPRD1,OPRD2功能: 两数相加说明:1. OPRD1为任一通用寄存器或存储器操作数,可以是任意一个通用寄存器,而且还可以是任意一个存储器操作数. OPRD2为立即数,也可以是任意一个通用寄存器操作数.立即数只能用于源操作数.2. OPRD1和OPRD2均为寄存器是允许的,一个为寄存器而另一个为存储器也是允许的, 但不允许两个都是存储器操作数.3. 加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.加法指令适用于无符号数或有符号数的加法运算.AND 逻辑与运算指令 AND格式: AND OPRD1,OPRD2功能: 对两个操作数实现按位逻辑与运算,结果送至目的操作数.本指令可以进行字节或字的‘与’运算,OPRD1<--OPRD1 and OPRD2. 说明:1. 目的操作数OPRD1为任一通用寄存器或存储器操作数.源操作数OPRD2为立即数,任一通用寄存器或存储器操作数.2. 示例: AND AL,0FH ;(AL)<--(AL) AND 0FHAND AX,BX ;(AX)<--(AX) AND (BX) AND DX,BUFFER[SI+BX]AND BETA[BX],00FFH注意: 两数相与,有一个数假则值为假CALL 过程调用指令 CALL格式: CALL OPRD 说明:1. 其中OPRD为过程的目的地址.功能: 过程调用指令 2. 过程调用可分为段内调用和段间调用两种.寻址方式也可以分为直接寻址和间接寻址两种.3. 本指令不影响标志位.CBW 字节扩展指令 CBW(Convert Byte to Word)格式: CBW功能: 将字节扩展为字,即把AL寄存器的符号位扩展到AH中. 说明:1. 两个字节相除时,先使用本指令形成一个双字节长的被除数.2. 本指令不影响标志位.3. 示例: MOV AL,25CBW IDIV BYTE PTR DATA1CLC 处理器控制指令-标志位操作指令格式:CLC ;置CF=0STC ;置CF=1CMC ;置CF=(Not CF)进位标志求反CLD ;置DF=0STD ;置DF=1CLI ;置IF=0,CPU禁止响应外部中断STI ;置IF=1使CPU允许向应外部中断功能: 完成对标志位的置位、复位等操作. 说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.CLD 处理器控制指令-标志位操作指令格式:CLC ;置CF=0STC ;置CF=1CMC ;置CF=(Not CF)进位标志求反CLD ;置DF=0STD ;置DF=1CLI ;置IF=0,CPU禁止响应外部中断STI ;置IF=1使CPU允许向应外部中断功能: 完成对标志位的置位、复位等操作. 说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.CLI 处理器控制指令-标志位操作指令格式:CLC ;置CF=0STC ;置CF=1CMC ;置CF=(Not CF)进位标志求反CLD ;置DF=0STD ;置DF=1CLI ;置IF=0,CPU禁止响应外部中断STI ;置IF=1使CPU允许向应外部中断功能: 完成对标志位置位、复位等操作. 说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.CMC 处理器控制指令-标志位操作指令格式: 说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操CLC ;置CF=0STC ;置CF=1CMC ;置CF=(Not CF)进位标志求反CLD ;置DF=0STD ;置DF=1CLI ;置IF=0,CPU禁止响应外部中断STI ;置IF=1使CPU允许向应外部中断功能: 完成对标志位的置位、复位等操作. 作指令执行时,按增量的方式修改吕指针.CMP 比效指令 CMP(CoMPare)格式: CMP OPRD1,OPRD2功能: 对两数进行相减,进行比较. 说明:1. OPRD1为任意通用寄存器或存储器操作数.OPRD2为任意通用寄存器或存储器操作数,立即数也可用作源操作数OPRD2.2. 对标志位的影响同SUB指令,完成的操作与SUB指令类似,唯一的区别是不将OPRD1-OPRD2的结果送回OPRD1,而只是比较.3. 在8088/8086指令系统中,专门提供了一组根据带符号数比较大小后,实现条件转移的指令.CMPS 字符串比较指令格式: CMPS OPRD1,OPRD2CMPSBCMPSW功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.同时SI,DI将自动调整. 说明:1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.CMPSB 字符串比较指令格式: CMPS OPRD1,OPRD2CMPSBCMPSW功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.同时SI,DI将自动调整. 说明:1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较CMPSW 字符串比较指令格式: CMPS OPRD1,OPRD2 说明:1. 其中OPRD2为源串符号地址,OPRD1CMPSBCMPSW功能: 由SI寻址的源串中数据与由DI 寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身. 同时SI,DI将自动调整. 为目的串符号地址.2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.CWD 字扩展指令 CWD(Convert Word toDouble Word)格式: CWD功能: 将字扩展为双字长,即把AX寄存器的符号位扩展到DX中. 说明:1. 两个字或字节相除时,先用本指令形成一个双字长的的被除数.2. 本指令不影响标志位.3. 示例: 在B1、B2、B3字节类型变量中,分别存有8们带符号数a、b、c,实现(a*b+c)/a运算。
汇编语言指令汇总

汇编语言指令汇总汇编语言是一种底层编程语言,用于编写计算机程序。
在汇编语言中,指令是执行特定操作的基本单元。
以下是一些常见的汇编语言指令的汇总:1.数据传输指令:-MOV:将源操作数的值复制到目的操作数。
-PUSH:将数据压入栈中。
-POP:从栈中弹出数据。
-LEA:将源操作数的有效地址加载到目的操作数中。
2.算术和逻辑指令:-ADD:将两个操作数相加,结果存储在目的操作数中。
-SUB:将第二个操作数从第一个操作数中减去,结果存储在目的操作数中。
-MUL:将两个操作数相乘,结果存储在目的操作数中。
-DIV:将第一个操作数除以第二个操作数,商存储在目的操作数中。
3.分支和循环指令:-JMP:无条件跳转到指定的地址。
-CMP:比较两个操作数的值。
-JZ/JNZ:当比较结果为零/非零时,跳转到指定的地址。
-JE/JNE:当比较结果为相等/不相等时,跳转到指定的地址。
-JG/JGE/JL/JLE:当比较结果为大于/大于等于/小于/小于等于时,跳转到指定的地址。
-LOOP:循环指令,根据计数寄存器的值重复执行指定的代码块。
4.中断指令:-INT:引发中断,将程序控制权转移到中断服务程序。
-IRET:从中断服务程序返回到调用程序。
5.位操作指令:-AND/OR/XOR:按位与/或/异或操作。
-NOT:按位取反操作。
-SHL/SHR:逻辑左移/逻辑右移操作。
6.I/O指令:-IN:从输入端口读取数据。
-OUT:向输出端口写入数据。
7.标志位操作指令:-CLC:清除进位标志位。
-STC:设置进位标志位。
-CLI:禁用中断。
-STI:启用中断。
8.字符串指令:-MOVS:将一个字符串从源地址移动到目的地址。
-CMPS:比较两个字符串的内容。
-LODS:从源地址加载一个字符或一个字符串。
-STOS:存储一个字符或一个字符串到目的地址。
9.其他指令:-NOP:空操作指令。
-HLT:停止运行指令。
以上只是一些常见的汇编语言指令,汇编语言的指令集因计算机体系结构而异。
汇编指令大全

汇编指令大全1. 引言汇编语言是一种基于计算机硬件体系结构的低级语言。
它用于编写与硬件交互的程序,并且具有直接访问计算机底层硬件的能力。
汇编指令是汇编语言中的基本操作指令,用于执行各种计算机操作,如数据传输、算术运算和逻辑运算等。
本文将为您介绍一些常见的汇编指令。
2. 数据传输指令数据传输指令用于在寄存器之间或内存和寄存器之间传输数据。
2.1 MOV - 数据传送指令mov是最常见的数据传送指令之一。
它用于将数据从一个源操作数传送到一个目的操作数。
mov destination, source其中,destination是目的操作数,source是源操作数。
这两个操作数可以是寄存器、内存地址或立即数。
2.2 LEA - 加载有效地址指令lea指令用于加载一个有效地址到一个目的操作数。
lea destination, source其中,destination是目的操作数,通常为一个寄存器,source是一个内存地址。
3. 算术运算指令算术运算指令用于执行加法、减法、乘法和除法等算术运算。
3.1 ADD - 加法指令add指令用于将两个操作数相加,并将结果存储在目的操作数中。
add destination, source其中,destination是目的操作数,source是源操作数。
这两个操作数可以是寄存器或内存地址。
3.2 SUB - 减法指令sub指令用于将第二个操作数从第一个操作数中减去,并将结果存储在目的操作数中。
sub destination, source其中,destination是目的操作数,source是源操作数。
这两个操作数可以是寄存器或内存地址。
3.3 MUL - 乘法指令mul指令用于将两个操作数相乘,并将结果存储在目的操作数中。
其中,destination是目的操作数,source是源操作数。
这两个操作数可以是寄存器或内存地址。
3.4 DIV - 除法指令div指令用于将目的操作数除以源操作数,并将商存储在目的操作数中,余数存储在另一个寄存器中。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
多字节数据的存储顺序汇编语言程序设计最小的存储单位:二进制位(比特位bit )►最常用的存储单位:字节(Byte ) 8个二进制位是一个字节►一个存储单元保存一个字节量数据►一个存储单元对应一个存储器地址D7D6D5D4D3D2D1D0字节FFFFFFFFH00000000H00000001H 00000002H 00000003H 00000004H变量保存于字节编址的主存储器中每个存储单元保存一个8位、字节量数据多个字节数据顺序逐个存放在主存相邻单元bvar6 byte 39h,31h,32h,38h wvar6 word 3139h,3832h dvar6 dword 38323139h 9128 9128 9128bvar6byte 39h,31h,32h,38h0338H 0232H 0131H 0039H地址低地址高地址wvar6 word 3139h,3832h32H 0338H 38H 0232H 39H 0131H 31H 0039H地址大端方式小端方式低地址高地址dvar6dword 38323139h39H 0338H 31H 0232H 32H 0131H 38H 0039H地址大端方式小端方式低地址高地址小端方式(Little Endian)•高字节数据保存在高地址存储单元•低字节数据保存在低地址存储单元大端方式(Big Endian)•高字节数据保存在低地址存储单元•低字节数据保存在高地址存储单元高对高、低对低高对低、低对高80x86采用小端方式存储多字节数据00405093H 38H 00405092H 32H 00405091H 31H 00405090H39H地址字节量:[00405090H]=39H 字量:[00405090H]=3139H双字量:[00405090H]=38323139H高对高、低对低主存储器采用字节编址►一个存储单元保存一个字节量数据►一个存储单元对应一个存储器地址对于N个字节的数据(N≥2)►存储在N个连续的存储单元、具有N个存储器地址►以最低地址表达该数据地址►存储采用小端方式:“高对高、低对低”或者采用大端方式:“高对低、低对高”变量的地址属性汇编语言程序设计变量定义变量名 变量定义伪指令 参数,参数…变量定义可以►分配存储空间►赋初值►创建变量名定义后的变量名具有两类属性(1)地址属性:首个变量所在存储单元的逻辑地址(2)类型属性:变量定义的数据单位…参数2参数1数据段变量名变量的地址属性指所在存储单元的逻辑地址►含有段基地址和偏移地址通过地址操作符获得变量的地址属性值[ ]括起的表达式作为存储器地址指针$返回当前偏移地址OFFSET 变量名返回变量名所在段的偏移地址SEG 变量名返回段基地址(实地址存储模型);数据段00000000 12 34bvar byte 12h,34h org $+10;当前地址(00000002H)加10,等于0000000CH 0000000C 0001 0002 0003 0004 0005 00060007 0008 0009 000Aarray word 1,2,3,4,5,6,7,8,9,10当前地址 0000002H 相对地址机器指令汇编语句00000020 5678wvar word 5678h =00000016 arr_size = $-array;计算出当前到ARRAY 变量所占存储空间=0000000B arr_len = arr_size/2;(除以类型值)计算出变量个数00000022 9ABCDEF0dvar dword 9abcdef0h 当前地址 00000022H array的地址 0000000CH 数据段使用变量名代表其偏移地址;代码段00000000 A0 00000000 Rmov al, bvar;bvar等同于[bvar] 00000005 8A 25 00000001 Rmov ah, bvar+1代码段使用变量名代表其首个数据(变量值)变量名加减常量指向首个数据的前后单元AL=12HAH=34H34H12H数据段bvar+1bvar byte 12h,34h0000000B 66|8B 1D 00000022 R mov bx, wvar[2]变量名[n] = 变量名+n常量n表示n个存储单元指向首个数据的前后单元BX=DEF0H 9AHBCH DEH F0H 56H 78H 数据段wvar +2dvar wvar word 5678hdvar dword 9abcdef0h00000012 B9 0000000B mov ecx, arr_len 00000017 BA 00000017 Rmov edx, $;$表示当前(指令)地址=0000000B arr_len = arr_size/2;(除以类型值)计算出变量个数ECX=0000000BHEDX=代码段地址+17H0000001C BE 00000022 Rmov esi, offset dvar 00000021 8B 3Emov edi, [esi];通过地址获得变量值00000023 8B 2D 00000022 Rmov ebp, dvar;直接获得变量值9AHBCHDEHF0H数据段dvar 00000022 9ABCDEF0 dvar dword 9abcdef0hESI=数据段地址+22HEDI=9ABCDEF0HEBP=9ABCDEF0H00000029 E8 00000000 Ecall disprd ;显示通用寄存器内容子程序名DISPRD功能说明显示8个32位通用寄存器内容运行结果EAX=00003412,EBX=7FFDDEF0,ECX=0000000B,EDX=00401017 ESI=00405022,EDI=9ABCDEF0,EBP=9ABCDEF0,ESP=0013FFC4;数据段bvar byte 12h,34horg $+10array word 1,2,3,4,5,6,7,8,9,10 wvar word 5678harr_size = $-arrayarr_len = arr_size/2dvar dword 9abcdef0h ;代码段mov al, bvarmov ah, bvar+1 mov bx, wvar[2] mov ecx, arr_len mov edx, $mov esi, offset dvar mov edi, [esi]mov ebp, dvar变量的类型属性汇编语言程序设计变量定义变量名 变量定义伪指令参数,参数…变量定义可以►分配存储空间►赋初值►创建变量名定义后的变量名具有两类属性(1)地址属性:首个变量所在存储单元的逻辑地址(2)类型属性:变量定义的数据单位…参数2参数1数据段变量名变量的类型属性表示变量定义的数据单位通过类型操作符获得变量的类型属性值变量定义类型名类型值(字节数)字节变量定义BYTE BYTE1字变量定义WORD WORD2双字变量定义DWORD DWORD4TYPE 变量名类型操作符使用变量名的类型属性类型名PTR 变量名将变量名按照指定的类型使用TYPE 变量名返回占用字节空间的字量数值LENGTHOF 变量名返回整个变量的数据项数SIZEOF 变量名返回整个变量占用的字节数;数据段bvar byte 12h,34horg $+10 ;间隔10个字节array word 1,2,3,4,5,6,7,8,9,10wvar word 5678h arr_size = $-arrayarr_len = arr_size/2dvar dword 9abcdef0h…00H 03H 00H 02H 00H 01H …34H 12Hbvararray9AH BCH DEHF0H 56H 78H 00H 0AH …wvardvar 数据段;代码段mov eax, dword ptr array …00H 03H 00H 02H 00H01H 34H 12Hbvararray 数据段EAX=00020001H寄存器具有确定的类型属性8位寄存器是字节类型byte 16位寄存器是字类型word 32位寄存器是双字类型dword被定义为字类型以双字类型访问mov ebx, type bvar ;获得字节变量类型值mov ecx, type wvar ;获得字变量类型值mov edx, type dvar ;获得双字变量类型值类型值就是每个数据所占的字节数字节类型byte 为1、字类型word 为2、双字类型dword 为4EBX=00000001H ECX=00000002H EDX=00000004Hmov esi, lengthof array;获得变量的数据个数(项数)mov edi, sizeof array;获得变量所占的存储空间个数ESI=0000000AH EDI=00000014H;数据段array word 1,2,3,4,5,6,7,8,9,10mov ebp, arr_size call disprd;显示寄存器内容EAX=00020001,EBX=00000001,ECX=00000002,EDX=00000004ESI=0000000A,EDI=00000014,EBP=00000016,ESP=0013FFC4EBP=00000016Harray word 1,2,3,4,5,6,7,8,9,10wvar word 5678h arr_size = $-array;数据段bvar byte 12h,34horg $+10array word 1,2,…,9,10 wvar word 5678harr_size = $-arrayarr_len = arr_size/2dvar dword 9abcdef0h ;代码段mov eax, dword ptr array mov ebx, type bvarmov ecx, type wvarmov edx, type dvarmov esi, lengthof array mov edi, sizeof array mov ebp, arr_sizecall disprd。