汇编语言基础知识

1、什么是汇编语言,它在计算机语言中的地位?

汇编语言是程序设计语言的基础语言,是唯一可以直接与计算机硬件打交道的语言

2、汇编语言源程序、汇编程序、汇编的关系?
这里写图片描述

3、汇编语言的特点

  1) 汇编语言与机器指令一一对应,可充分理解计算机的操作过程
      汇编语言指令是机器指令的符号表示

  2) 汇编语言是靠近机器的语言
      编程时要求熟悉机器硬件系统,可充分利用机器硬件中的全部功能,发挥机器的特点
      在计算机系统中,某些功能由汇编语言程序实现:实时过程控制系统、系统初始化、实际的输入输出设备操作

  3) 汇编语言程序的效率高于高级语言
      效率,指的是用汇编语言编写的源程序在汇编后所得的目标程序效率高
      时间域的高效率:运行速度快;空间域的高效率:目标代码占用存储空间少

4、汇编语言与高级语言的比较

5、进制转换

 (略)

6、数据组织单位

 1) 位(bit)
     是计算机中表示信息的最小单位,符号b,是一个二进制位,每一位用0或1表示

 2) 字节(Byte) 
     8位二进制数为一个字节

 3) 字(Word)
     若干个字节为一个字,一般一个字包含两个字节
     范围0000H~FFFFH

 4) 双字(Double Word)
     两个字节为一个字,四个字节为连个字,称为双字
     范围00000000H~FFFFFFFFH

 5) 字长
     机器字的长度为字长,即计算机中每个字所包含的位数,由机器数据总线数决定
     例如,数据总线数为64位,机器字长为64位,即每个字有8个字节

 6) 数据字与指令字
     数据字:在存储单元中存储的是数据
     指令字:在存储单元中存储的是指令
     无论是数据字还是指令字,在存储单元中都是以二进制的形式存放的

7、BCD码

 两种存储方式:组合型(1个字节表示2个BCD码);非组合型(1个字节表示1个BCD码)

8、80X86计算机组织结构

 微型计算机的硬件系统主要由3个主要部分组成:
  1)中央处理器CPU(运算器、控制器、寄存器)
  2)输入输出设备
  3)存储器

9、80X86 CPU的寄存器

  寄存器分为3类:
  1)通用寄存器
  2)控制寄存器
  3)段寄存器

  8个8位通用寄存器:AL,AH,BL,BH,CL,CH,DL,DH
  8个16位通用寄存器:AX,BX,CX,DX,SI,DI,BP,SP
  8个32位通用寄存器:EAX,EBX,ECX,EDX,ESI,EDI,EBP,ESP

说明:1)指针寄存器(SP,ESP,BP,EBP)

		SP,ESP为堆栈指针寄存器,存放当前堆栈段栈顶的偏移地址,
		是根据指令自动移动的,要想随机读取
	
		堆栈段中的数据,必须通过BP或EBP基址指针寄存器来读取。


	2)控制寄存器(IP,EIP,FLAGS,EFLAGS)

		IP,EIP为指令指针寄存器,用于存放当前正在执行的指令的
		下一条指令的偏移地址,该寄存器所指的为代码段的偏移地址。

         FLAGS为标识寄存器,表示程序运行时的状态和一些特殊控制

	3)段寄存器
		
		代码和数据是分开存放,代码存放在代码段,数据存放在数据段

10、内存组织结构

1)内存的地址

	在存储器中内存单元的基本单位是*字节*,每个字节都有一个唯一的地址

2)存储单元的内容

	一个存储单元存放的信息为存储单元的内容
		分为:字节单元、字单元、双字单元
		双字:需要两个16位寄存器,通常为DX:AX,DX高位,AX低位

3)堆栈

	堆栈是内存中一块特定的区域,其中数据按照*先进后出*原则
	作用:暂存数据、子程序调用与返回、调用中断处理程序、从中断处理程序返回
	位置:堆栈段地址存放于SS寄存器中,偏移地址存放在堆栈指针寄存器(SP(16位)/ESP(32位)),
		 他们永远指向栈顶
	初始化:堆栈的初始化时通过设置SS及SP/ESP值来完成的,可以由编译系统自动完成,也可以在程序
		   中通过伪指令显示地定义

11、实模式

1)介绍
	
	只有8086/8088工作在实模式下;
	80286以上的微处理器工作在实模式和保护模式下;
	在实模式下微处理器只能寻址1MB的存储空间;
	80286以上系统的微处理器在加点或复位时都以实模式方式开始工作

2)内存地址的分段

	*为什么要分段?*
	8086/8088地址总线为20根,可访问的地址为:2^20=1048576=1M
	8086/8088内部寄存器都是16位的,可以直接处理16位长度的存储地址,16位地址的寻址2^16=64K
	为了把寻址范围扩大到1MB,实模式存储器地址均采用存储空间的分段技术来解决寻址1MB的存储空间
	提出了段地址和偏移地址合成20位物理地址的概念
	
	
	*分段方法?*
	16位段地址+16位段内地址--->20位物理地址
	地址的组合:物理地址=段地址*16D(或10H)+偏移地址,(段地址*16D--二进制段地址左移4位)
	存放段地址:16位段地址寄存器(CS、DS、SS、ES)
	存放偏移地址:16位指针寄存器(IP、SP)
	在1MB存储器中可以有64K个段,每个段最多64KB,最小为16KB
	

	*物理地址、段地址、段内地址、逻辑地址的区别?*
	物理地址:与内存单元一一对应的20位二进制数,1MB=00000H~FFFFFH
		    每个物理地址代表一个唯一的内存单元
	
	段地址:将1MB的内存空间分为长64KB的程序区和数据区称为段
		  每个段用1个16位二进制地址表示
		  段地址存放在段寄存器中
		  代码段:用于存放源程序的二进制程序代码,该段的段地址放在CS中
		  数据段:存放操作数据的,该段的段地址放在DS中
		  堆栈段:堆栈用的存储区,该段的段地址放在SS中
		  附加段:该段的段地址放在ES中
	
	段内地址:16位二进制段内地址为偏移地址
   (偏移地址)不同段内的偏移地址存放在不同的寄存器中,段寄存器与装偏移地址的寄存器按一定要求组合

段寄存器与偏移地址寄存器组合

	逻辑地址:用段地址和偏移地址来表示内存单元的地址为逻辑地址,例如,段地址:偏移地址

	
	*逻辑地址与物理地址的换算关系?*
	物理地址 = 段地址*16D(10H)+偏移地址
	逻辑地址 = 段地址:偏移地址
	例子:逻辑地址,1111H:2222H
		 物理地址,1111H*10H+2222H = 13332H
		 假设1111H为代码段地址,2222H在指针寄存器IP中,示意图如下:

内存地址示意图

	*内存分配方法?*
	代码段、数据段、堆栈段的大小,是以节为最小单位分配内存区域的
	16字节=2个字=1节,节的边界地址就是能够被16整除的地址
	偏移地址(段内地址)是从0000H开始的
	例子:假设程序分配的内存区从6100H开始,程序长度1020字节,操作数510字节,堆栈段250字节
		 则代码段长度为1024D=400H,数据段长度为512D=200H,堆栈段长度为256D=100H
		 示意图如下:

	*段与段之间的关系?*
	8088/8086 CPU把1MB的存储空间划分成若干逻辑段
	每个段的起始地址必须是能够被16整除的数
	逻辑段的最大长度为64KB
	1MB的存储空间最多可以分成64K个逻辑段,当每个逻辑段为16KB时
	段与段之间可以相邻、分离、重叠、部分重叠

12、保护模式

1)保护模式存储器寻址机制

	在保护模式下,逻辑地址=选择符+偏移地址
	与实模式不同,实模式的段寄存器存放段基地址,而保护模式的段寄存器存放选择符
	保护模式下,通过选择描述符表中的描述符,间接地形成段基地址
	保护模式的偏移地址最大可以是32位,最大段长可以从16KB扩展到4GB

2)描述符

	描述符包括,段在寄存器中的位置,段的长度,访问权限
	
	由基地址、段界限、访问权限、附加字段组成
		基地址:指定段的起始地址
		段界限:存放该段的最大偏移地址
		访问权限:说明该段在系统中的功能和一些控制信息
		附加字段:描述该段的一些属性
	
	描述符的内容是由系统自动设置的

	由于段寄存器是16位的,描述符是64位的
	故将64位的段描述符放按顺序存放形成一个段描述符表,放在内存中
	而在段寄存器中实际存放的是要选择的段描述符表的序号,类似于数组中的下标

13、存储器管理机制

	1)分段管理机制
		
		①虚拟存储器:在有限的物理存储器上获取更大的使用空间
			*虚拟存储器是如何实现存储的?*
			在程序执行期间的任意时刻,虚拟存储器系统自动吧程序分成许多小块即程序段
			将某个程序段存放到物理存储器中,其他程序段放在磁盘中
			当程序要访问到哪个程序段时,就把哪个程序段引导到物理存储器中
		
		②分段管理:将4GB的存储空间分成若干独立的受保护的存储空间块
				  每个应用程序可以使用这些存储空间块
	
	2)分页管理机制
	
		①线性地址空间:每个进程都有相同大小的4GB线性空间
					 用分段管理机制实现虚拟地址空间到线性地址空间的映射,实现把二维的
					 虚拟地址转换为一维的线性地址

		②分页存储管理:把线性地址空间和物理地址空间分别划分为大小相同的块,每块长为4KB
		              这样的块称为页,通过分页管理机制实现线性地址空间到物理地址空间的
		              映射,实现线性地址到物理地址的转换
课程介绍 第1章 预备知识  1.1 汇编语言的由来及其特点   1 机器语言   2 汇编语言   3 汇编程序   4 汇编语言的主要特点   5 汇编语言的使用领域  1.2 数据的表示和类型   1 数值数据的表示   2 非数值数据的表示   3 基本的数据类型  1.3 习题 第2章 CPU资源和存储器  2.1 寄存器组   1 寄存器组   2 通用寄存器的作用   3 专用寄存器的作用  2.2 存储器的管理模式   1 16位微机的内存管理模式   2 32位微机的内存管理模式  2.3 习题 第3章 操作数的寻址方式  3.1 立即寻址方式  3.2 寄存器寻址方式  3.3 直接寻址方式  3.4 寄存器间接寻址方式  3.5 寄存器相对寻址方式  3.6 基址加变址寻址方式  3.7 相对基址加变址寻址方式  3.8 32位地址的寻址方式  3.9 操作数寻址方式的小结  3.10 习题 第4章 标识符和表达式  4.1 标识符  4.2 简单内存变量的定义   1 内存变量定义的一般形式   2 字节变量   3 字变量   4 双字变量   5 六字节变量   6 八字节变量   7 十字节变量  4.3 调整偏移量伪指令   1 偶对齐伪指令   2 对齐伪指令   3 调整偏移量伪指令   4 偏移量计数器的值  4.4 复合内存变量的定义   1 重复说明符   2 结构类型的定义   3 联合类型的定义   4 记录类型的定义   5 数据类型的自定义  4.5 标号  4.6 内存变量和标号的属性   1 段属性操作符   2 偏移量属性操作符   3 类型属性操作符   4 长度属性操作符   5 容量属性操作符   6 强制属性操作符   7 存储单元别名操作符  4.7 表达式   1 进制伪指令   2 数值表达式   3 地址表达式  4.8 符号定义语句   1 等价语句   2 等号语句   3 符号名定义语句  4.9 习题 第5章 微机CPU的指令系统  5.1 汇编语言指令格式   1 指令格式   2 了解指令的几个方面  5.2 指令系统   1 数据传送指令   2 标志位操作指令   3 算术运算指令   4 逻辑运算指令   5 移位操作指令   6 位操作指令   7 比较运算指令   8 循环指令   9 转移指令   10 条件设置字节指令   11 字符串操作指令   12 ASCII-BCD码调整指令   13 处理器指令  5.3 习题 第6章 程序的基本结构  6.1 程序的基本组成   1 段的定义   2 段寄存器的说明语句   3 堆栈段的说明   4 源程序的结构  6.2 程序的基本结构   1 顺序结构   2 分支结构   3 循环结构  6.3 段的基本属性   1 对齐类型   2 组合类型   3 类别   4 段组  6.4 简化的段定义   1 存储模型说明伪指令   2 简化段定义伪指令   3 简化段段名的引用  6.5 源程序的辅助说明伪指令   1 模块名定义伪指令   2 页面定义伪指令   3 标题定义伪指令   4 子标题定义伪指令  6.6 习题 第7章 子程序和库  7.1 子程序的定义  7.2 子程序的调用和返回指令   1 调用指令   2 返回指令  7.3 子程序的参数传递   1 寄存器传递参数   2 存储单元传递参数   3 堆栈传递参数  7.4 寄存器的保护与恢复  7.5 子程序的完全定义   1 子程序完全定义格式   2 子程序的位距   3 子程序的语言类型   4 子程序的可见性   5 子程序的起始和结束操作   6 寄存器的保护和恢复   7 子程序的参数传递   8 子程序的原型说明   9 子程序的调用伪指令   10 局部变量的定义  7.6 子程序库   1 建立库文件命令   2 建立库文件举例   3 库文件的应用   4 库文件的好处  7.7 习题 第8章 输入输出和中断  8.1 输入输出的基本概念   1 I/O端口地址   2 I/O指令  8.2 中断   1 中断的基本概念   2 中断指令   3 中断返回指令   4 中断和子程序  8.3 中断的分类   1 键盘输入的中断功能   2 屏幕显示的中断功能   3 打印输出的中断功能   4 串行通信口的中断功能   5 鼠标的中断功能   6 目录和文件的中断功能   7 内存管理的中断功能   8 读取和设置中断向量  8.4 习题 第9章 宏  9.1 宏的定义和引用   1 宏的定义   2 宏的引用   3 宏的参数传递方式   4 宏的嵌套定义   5 宏与子程序的区别  9.2 宏参数的特殊运算符   1 连接运算符   2 字符串整体传递运算符   3 字符转义运算符   4 计算表达式运算符  9.3 与宏有关的伪指令   1 局部标号伪指令   2 取消宏定义伪指令   3 中止宏扩展伪指令  9.4 重复汇编伪指令   1 伪指令REPT   2 伪指令IRP   3 伪指令IRPC  9.5 条件汇编伪指令   1 条件汇编伪指令的功能   2 条件汇编伪指令的举例  9.6 宏的扩充   1 宏定义形式   2 重复伪指令REPEAT   3 循环伪指令WHILE   4 循环伪指令FOR   5 循环伪指令FORC   6 转移伪指令GOTO   7 宏扩充的举例   8 系统定义的宏  9.7 习题 第10章 应用程序的设计  10.1 字符串的处理程序  10.2 数据的分类统计程序  10.3 数据转换程序  10.4 文件操作程序  10.5 动态数据的编程  10.6 COM文件的编程  10.7 驻留程序  10.8 程序段前缀及其应用   1 程序段前缀的字段含义   2 程序段前缀的应用  10.9 习题 第11章 数值运算协处理器  11.1 协处理器的数据格式   1 有符号整数   2 BCD码数据   3 浮点数  11.2 协处理器的结构  11.3 协处理器的指令系统   1 操作符的命名规则   2 数据传送指令   3 数学运算指令   4 比较运算指令   5 超越函数运算指令   6 常数操作指令   7 协处理器控制指令  11.4 协处理器的编程举例  11.5 习题 第12章 汇编语言和C语言  12.1 汇编语言的嵌入  12.2 C语言程序的汇编输出  12.3 一个具体的例子  12.4 习题 附录
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值