汇编语言第二版(全部)课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《汇编语言第二版(全部)课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 汇编语言 第二 全部 课件
- 资源描述:
-
1、第1章 基础知识 1.1 机器语言 1.9 数据总线 1.2 汇编语言的产生 1.10 控制总线 1.3 汇编语言的组成 1.11 内存地址空间(概述)1.4 存储器 1.12 主板 1.5 指令和数据 1.13 接口卡 1.6 存储单元 1.14 各类存储器芯片 1.7 CPU对存储器的读写 1.15 内存地址空间 1.8 地址总线 引言 汇编语言是直接在硬件之上工作的编程语言,首先要了解硬件系统的结构,才能有效的应用汇编语言对其编程。在本章中,对硬件系统结构的问题进行一部分的探讨,以使后续的课程可在一个好的基础上进行。引言 当课程进行到需要补充新的基础知识(关于编程结构或其他的)时候,再对
2、相关的基础知识进行介绍和探讨。本书的原则是,以后用到的知识,以后再说。引言 汇编课程的研究重点放在如何利用硬件系统的编程结构和指令集有效灵活的控制系统进行工作。1.1 机器语言 机器语言是机器指令的集合。机器指令展开来讲就是一台机器可以正确执行的命令。1.1 机器语言 指令:01010000(PUSH AX)电平脉冲:1.1 机器语言 以后我们提到的计算机是指由CPU 和其他受CPU 直接或间接控制的芯片、器件、设备组成的计算机系统;比如我们最常见的PC 机。1.1 机器语言 程序员们将 0、1 数字编程的程序代码打在纸带或卡片上,1打孔,0不打孔,再将程序通过纸带机或卡片机输入计算机,进行运
3、算。示例 应用8086CPU完成运算:S=768+12288 12801.1 机器语言 S=768+12288-1280 机器码:101100000000000000000011 000001010000000000110000 001011010000000000000101 假如将程序错写成以下这样,请找处错误:101100000000000000000011 000001010000000000110000 0001011010000000000001011.1 机器语言 在显示器上输出“welcome to masm”。机器码 看到这样的程序,你会有什么感想?如果程序里有一个“1”被误
4、写为“0”,又如何去查找呢?1.2 汇编语言的产生 汇编语言的主体是汇编指令。汇编指令和机器指令的差别在于指令的表示方法上。汇编指令是机器指令便于记忆的书写格式。汇编指令是机器指令的助记符。1.2 汇编语言的产生 机器指令:1000100111011000 操作:寄存器BX的内容送到AX中 汇编指令:MOV AX,BX 这样的写法与人类语言接近,便于阅读和记忆。寄存器 寄存器:简单的讲是CPU中可以存储数据的器件,一个CPU中有多个寄存器。AX是其中一个寄存器的代号,BX是另一个寄存器的代号。更详细的内容我们在以后的课程中将会讲到。1.2 汇编语言的产生 计算机能读懂的只有机器指令,那么如何让
5、计算机执行程序员用汇编指令编写的程序呢?用汇编语言编写程序的工作过程1.3 汇编语言的组成 汇编语言由以下3类组成:1、汇编指令(机器码的助记符)2、伪指令 (由编译器执行)3、其它符号(由编译器识别)汇编语言的核心是汇编指令,它决定了汇编语言的特性。1.4 存储器 CPU 是计算机的核心部件它控制整个计算机的运作并进行运算,要想让一个CPU 工作,就必须向它提供指令和数据。指令和数据在存储器中存放,也就是平时所说的内存。1.4 存储器 在一台PC机中内存的作用仅次于CPU。离开了内存,性能再好的CPU也无法工作。1.4 存储器 磁盘不同于内存,磁盘上的数据或程序如果不读到内存中,就无法被CP
6、U 使用。1.5 指令和数据 指令和数据是应用上的概念。在内存或磁盘上,指令和数据没有任何区别,都是二进制信息。1.5 指令和数据 二进制信息:1000100111011000 89D8H(数据)1000100111011000 MOV AX,BX(程序)1.6 存储单元 存储器被划分为若干个存储单元,每个存储单元从0开始顺序编号;例如:一个存储器有128个存储单元,编号从0127。如右图示:1.6 存储单元 对于大容量的存储器一般还用以下单位来计量容量(以下用B来代表Byte):1KB=1024B 1MB=1024KB 1GB=1024MB 1TB=1024GB 磁盘的容量单位同内存的一样,
7、实际上以上单位是微机中常用的计量单位。1.7 CPU对存储器的读写 CPU要想进行数据的读写,必须和外部器件(标准的说法是芯片)进行三类信息的交互:存储单元的地址(地址信息)器件的选择,读或写命令(控制信息)读或写的数据(数据信息)1.7 CPU对存储器的读写 那么CPU是通过什么将地址、数据和控制信息传到存储芯片中的呢?电子计算机能处理、传输的信息都是电信号,电信号当然要用导线传送。1.7 CPU对存储器的读写 在计算机中专门有连接CPU和其他芯片的导线,通常称为总线。物理上:一根根导线的集合;逻辑上划分为:地址总线 数据总线 控制总线 图示1.7 CPU对存储器的读写 总线在逻辑上划分的图
8、示:1.7 CPU对存储器的读写 CPU在内存中读或写的数据演示:读演示 写演示 从上面我们知道CPU是如何进行数据读写的。可是我们如何命令计算机进行数据的读写呢?1.7 CPU对存储器的读写1.7 CPU对存储器的读写1.7 CPU对存储器的读写 对于8086CPU,下面的机器码能够完成从3号单元读数据:机器码:101000000000001100000000 含义:从3号单元读取数据送入寄存器AX CPU接收这条机器码后将完成上面所述的读写工作。1.7 CPU对存储器的读写 机器码难于记忆,用汇编指令来表示,情况如下:机器码:101000000000001100000000 对应的汇编指令
9、:MOV AX,3 含义:传送3号单元的内容到AX1.8 地址总线 CPU是通过地址总线来指定存储单元的。地址总线上能传送多少个不同的信息,CPU就可以对多少个存储单元进行寻址。1.8 地址总线 地址总线发送地址信息演示1.8 地址总线1.8 地址总线 一个CPU有N根地址总线,则可以说这个CPU的地址总线的宽度为N。这样的CPU最多可以寻找的N次方个内存单元。1.9 数据总线 CPU与内存或其它器件之间的数据传送是通过数据总线来进行的。数据总线的宽度决定了CPU和外界的数据传送速度。1.9 数据总线 我们来分别看一下它们向内存中写入数据89D8H时,是如何通过数据总线传送数据的:8088CP
10、U数据总线上的数据传送情况 8086CPU数据总线上的数据传送情况1.9 数据总线 8位数据总线上传送的信息1.9 数据总线 16位数据总线上传送的信息1.10 控制总线 CPU对外部器件的控制是通过控制总线来进行的。在这里控制总线是个总称,控制总线是一些不同控制线的集合。有多少根控制总线,就意味着CPU提供了对外部器件的多少种控制。所以,控制总线的宽度决定了CPU对外部器件的控制能力。控制总线上发送的控制信息1.10 控制总线1.10 控制总线 前面所讲的内存读或写命令是由几根控制线综合发出的:其中有一根名为读信号输出控制线负责由CPU 向外传送读信号,CPU 向该控制线上输出低电平表示将要
11、读取数据;有一根名为写信号输出控制线负责由CPU向外传送写信号。1.1节1.10节 小结(1)汇编指令是机器指令的助记符,同机器指令一一对应。(2)每一种CPU都有自己的汇编指令集。1.1节1.10节 小结(3)CPU可以直接使用的信息在存储器中存放。(4)在存储器中指令和数据没有任何区别,都是二进制信息。1.1节1.10节 小结(5)存储单元从零开始顺序编号。(6)一个存储单元可以存储 8 个 bit(用作单位写成“b”),即 8 位二进制数。(7)1B=8b1KB=1024B 1MB=1024KB 1GB=1024MB1.1节1.10节 小结(续)(8)每一个CPU芯片都有许多管脚,这些管
12、脚和总线相连。也可以说,这些管脚引出总线。一个CPU可以引出三种总线的宽度标志了这个CPU的不同方面的性能:地址总线的宽度决定了CPU的寻址能力;数据总线的宽度决定了CPU与其它器件进行数据传送时的一次数据传送量;控制总线宽度决定了CPU对系统中其它器件的控制能力。1.1节1.10节 小结(续)在汇编课程中,我们从功能的角度介绍了这三类总线,对实际的连接情况不做讨论。特别提示特别提示 检测点 1.1(Page 8)没有通过检测点请不要向下学习!1.11 内存地址空间(概述)什么是内存地址空间呢?一个CPU的地址线宽度为10,那么可以寻址1024个内存单元,这1024个可寻到的内存单元就构成这个
13、CPU的内存地址空间。下面深入讨论。首先需要介绍两部分基本知识,主板和接口卡。1.12 主板 在每一台PC机中,都有一个主板,主板上有核心器件和一些主要器件。这些器件通过总线(地址总线、数据总线、控制总线)相连。1.13 接口卡 计算机系统中,所有可用程序控制其工作的设备,必须受到CPU的控制。CPU对外部设备不能直接控制,如显示器、音箱、打印机等。直接控制这些设备进行工作的是插在扩展插槽上的接口卡。1.14 各类存储器芯片 从读写属性上看分为两类:随机存储器(RAM)和只读存储器(ROM)从功能和连接上分类:随机存储器RAM 装有BIOS的ROM 接口卡上的RAM PC机中各类存储器的逻辑连
14、接情况1.14 各类存储器芯片 装有BIOS的ROM BIOS:Basic Input/Output System,基本输入输出系统。BIOS是由主板和各类接口卡(如:显卡、网卡等)厂商提供的软件系统,可以通过它利用该硬件设备进行最基本的输入输出。在主板和某些接口卡上插有存储相应BIOS的ROM。1.15 内存地址空间 上述的那些存储器在物理上是独立的器件。但是它们在以下两点上相同:1、都和CPU的总线相连。2、CPU对它们进行读或写的时候都通过控制线发出内存读写命令。1.15 内存地址空间 将各各类存储器看作一个逻辑存储器:所有的物理存储器被看作一个由若干存储单元组成的逻辑存储器;每个物理存
15、储器在这个逻辑存储器中占有一个地址段,即一段地址空间;CPU在这段地址空间中读写数据,实际上就是在相对应的物理存储器中读写数据。1.15 内存地址空间 假设,上图中的内存空间地址段分配如下:地址07FFFH的32KB空间为主随机存储器的地址空间;地址8000H9FFFH的8KB空间为显存地址空间;地址A000HFFFFH的24KB空间为各个ROM的地址空间。1.15 内存地址空间 不同的计算机系统的内存地址空间分配情况是不同的。8086PC机内存地址空间分配的基本情况8086PC机的内存地址空间分配1.15 内存地址空间 内存地址空间:最终运行程序的是CPU,我们用汇编编程的时候,必须要从CP
16、U角度考虑问题。对CPU来讲,系统中的所有存储器中的存储单元都处于一个统一的逻辑存储器中,它的容量受CPU寻址能力的限制。这个逻辑存储器即是我们所说的内存地址空间。小结汇编语言课件王爽 著清华大学出版社制作工具:Microsoft PowerPoint2003本课件由汇编网()制作提供第2章 寄存器(CPU工作原理)2.1 通用寄存器 2.2 字在寄存器中的存储 2.3 几条汇编指令 2.4 物理地址 2.5 16位结构的CPU 2.6 8086CPU给出物理地址的方法 2.7“段地址16+偏移地址 =物理地址”的本质含义 2.8 段的概念 2.9 段寄存器 2.10 CS和IP 2.12 代
17、码段CPU概述 一个典型的CPU由运算器、控制器、寄存器等器件组成,这些器件靠内部总线相连。内部总线实现CPU内部各个器件之间的联系。外部总线实现CPU和主板上其它器件的联系。寄存器概述 8086CPU有14个寄存器 它们的名称为:AX、BX、CX、DX、SI、DI、SP、BP、IP、CS、SS、DS、ES、PSW。这些寄存器以后会陆续介绍2.1 通用寄存器 8086CPU所有的寄存器都是16位的,可以存放两个字节。AX、BX、CX、DX 通常用来存放一般性数据被称为通用寄存器。下面以AX为例,我们看一下寄存器的逻辑结构。一个16位寄存器可以存储一个16位的数据。(数据的存放情况)一个16位寄
18、存器所能存储的数据的最大值为多少?答案:216-1。2.1 通用寄存器16位数据在寄存器中的存放情况 数据:18 二进制表示:10010 在寄存器AX中的存储:16位数据在寄存器中的存放情况 数据:20000 二进制表示:0100111000100000 在寄存器AX中的存储:2.1 通用寄存器 8086上一代CPU中的寄存器都是8位的;为保证兼容性,这四个寄存器都可以分为两个独立的8位寄存器使用。AX可以分为AH和AL;BX可以分为BH和BL;CX可以分为CH和CL;DX可以分为DH和DL。8086CPU的8位寄存器存储逻辑2.1 通用寄存器 以AX为例,8086CPU的16位寄存器分为两个
19、8位寄存器的情况:2.1 通用寄存器 AX的低8位(0位7位)构成了AL寄存器,高8位(8位15位)构成了AH寄存器。AH和AL寄存器是可以独立使用的8位寄存器。8086CPU的8位寄存器数据存储情况 一个8位寄存器所能存储的数据的最大值是多少?答案:28-1。2.1 通用寄存器2.2 字在寄存器中的存储 一个字可以存在一个16位寄存器中,这个字的高位字节和低位字节自然就存在这个寄存器的高8位寄存器和低8位寄存器中。关于数制的讨论 由于一个内存单元可以存放 8位数据,CPU中的寄存器又可存放 n 个 8位数据。也就是说,计算机中的数据大多 是由1N个8位数据构成的。用十六进制来表示数据可以直观
20、的看 出这个数据是由哪些8位数据构成的。示例2.3 几条汇编指令汇编指令不区分大小写2.3 几条汇编指令 CPU执行下表中的程序段的每条指令后,对寄存器中的数据进行的改变。2.3 几条汇编指令2.3 几条汇编指令 这里的丢失,指的是进位制不能在 8 位寄存器中保存,但是 CPU 不是并真的不丢弃 这个进位值,这个问题会在后面的课程中讨论。特别提示 检测点2.1(Page 18)没有通过检测点请不要向下学习!2.4 物理地址 CPU访问内存单元时要给出内存单元的地址。所有的内存单元构成的存储空间是一个一维的线性空间。每一个内存单元在这个空间中都有唯一的地址,这个唯一的地址称为物理地址。2.5 1
21、6位结构的CPU 概括的讲,16位结构描述了一个CPU具有以下几个方面特征:1、运算器一次最多可以处理16位的数据。2、寄存器的最大宽度为16位。3、寄存器和运算器之间的通路是16位的。2.6 8086CPU给出物理地址的方法 8086有20位地址总线,可传送20位地址,寻址能力为1M。8086内部为16位结构,它只能传送16位的地址,表现出的寻址能力却只有64K。2.6 8086CPU给出物理地址的方法 8086CPU采用一种在内部用两个16位地址合成的方法来形成一个20位的物理地址。8086CPU相关部件的逻辑结构在8086CPU内部用两个16位地址合成的方法来形成一个20位的物理地址地址
22、加法器 地址加法器合成物理地址的方法:物理地址=段地址16+偏移地址 例如:8086CPU访问地址为123C8H的内存单元 由段地址16引发的讨论 观察移位次数和各种形式数据的关系:(1)一个数据的二进制形式左移1位,相当于该数据乘以2;(2)一个数据的二进制形式左移N位,相当于该数据乘以2的N次方;(3)地址加法器如何完成段地址16的运算?以二进制形式存放的段地址左移4位。由段地址16引发的讨论2.7“段地址16+偏移地址=物理地址”的本质含义 两个比喻说明:说明“基础地址+偏移地址=物理地址”的思想:第一个比喻 说明“段地址16+偏移地址=物理地址”的思想:第二个比喻 8086CPU就是这
23、样一个只能提供两张3位数据纸条的CPU。“基础地址+偏移地址=物理地址”比如说,学校、体育馆同在一条笔直的单行路上(学校位于路的起点0米处)。读者在学校,要去图书馆,问我那里的地址,我可以用几种方式描述这个地址?“基础地址+偏移地址=物理地址”(1)从学校走2826m到图书馆。这2826可以认为是图书馆的物理地址。(2)从学校走2000m到体育馆,从体育馆再走826m到图书馆。第一个距离2000m是相对于起点的基础地址;第二个距离826m是将对于基础地址的偏移地址。“段地址16+偏移地址=物理地址”比如我们只能通过纸条来通信,读者问我图书馆的地址,我只能将它写在纸上告诉读者。显然我必须有一张可
24、以容纳 4 位数据的纸条才能写下2826这个数据:“段地址16+偏移地址=物理地址”不巧的是,没有能容纳4位数据的纸条,仅有两张可以容纳3位数据的纸条。这样我只能以这种方式告诉读者2826这个数据:2.8 段的概念 错误认识:内存被划分成了一个一个的段,每一个段有一个段地址。其实:内存并没有分段,段的划分来自于CPU,由于8086CPU用“(段地址16)+偏移地址=物理地址”的方式给出内存单元的物理地址,使得我们可以用分段的方式来管理内存。2.8 段的概念 我们可以认为:地址10000H100FFH的内存单元组成一个段,该段的起始地址(基础地址)为10000H,段地址为1000H,大小为100
25、H。2.8 段的概念 我们也可以认为地址10000H1007FH、10080H100FFH 的内存单元组成两个段,它们的起始地址(基础地址)为10000H和10080H,段地址为:1000H 和1008H,大小都为80H。2.8 段的概念 以后,在编程时可以根据需要,将若干地址连续的内存单元看作一个段,用段地址16定位段的起始地址(基础地址),用偏移地址定位段中的内存单元。两点需要注意 内存单元地址小结 特别提示两点需要注意(1)段地址16 必然是 16的倍数,所以一个段的起始地址也一定是16的倍数;(2)偏移地址为16位,16 位地址的寻址能力为 64K,所以一个段的长度最大为64K。内存单
展开阅读全文