汇编语言是和具体的微处理器相联系的,每一种微处理器的汇编语言都不一样,只能通过一种常用的结构简洁的微处理器的汇 编语言来进行学习。 我们采用8086CPU为中央处理器的PC机来进行学习。8086CPU结构简洁,便于进行教学。 说到汇编语言的产生,首先要讲一下机器语言。机器语言是机器指令的集合。什么是机器指令?我们在使用CE时,常常见到。 请看下图: file:///C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\ksohtml\wps39E.tmp.png 图中所示的就是机器指令(或称机器码),这是十六进制的,如果要让计算机识别,则必须是二进制的。如机器指令 89 5C 24 38,转化为二进制是 10001001010111000010010000111000 ,你看得懂这条机器指令的含义是什么吗?不懂是吧,我也不懂 ,可见,机器指令是如此的晦涩难懂,于是汇编语言便产生了。 汇编语言的主体是汇编指令,汇编指令我们在使用CE时,也是常常见到,见下图: file:///C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\ksohtml\wps39F.tmp.png 汇编指令和机器指令是一一对应的。比如:机器指令 89D8和汇编指令mov ax,bx的含义是相同的,然而我们很难懂 89D8 的含义是什么,mov ax,bx的含义一看就懂了,其含义是:把寄存器bx中的数据送给ax。汇编指令的写法与人类语言接近,便于 阅读和记忆。既然有了如此简明易懂的汇编指令,为什么不把机器指令抛掉?指令最终是由CPU来执行的,但CPU只认识机器指 令,不认识汇编指令,所以抛不了的。汇编指令是给人看的,机器指令是给CPU看的。 有一个东西可以把汇编指令翻译成机器指令,这个东西就是编译器。 程序员用汇编语言写出源程序,再用编译器将其编译为机器码,由计算机最终执行,下图描述了这个工作过程。 file:///C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\ksohtml\wps3A0.tmp.png CPU是计算机的核心部件,它控制整个计算机的运作并进行运算,要想让一个CPU工作,就必须向它提供指令和数据,指令 和数据在存储器中存放,也就是我们平常说的内存。 在内存中,指令和数据没有任何区别,都是二进制信息,CPU在工作的时候,把有的信息看作指令,把有的信息看作数据,为 同样的信息赋予了不同的意义。 例如:内存中的二进制信息 1000100111011000,计算机既可把它看作大小为 89D8H的数据来处理,也可以把它看作指 令 mov ax,bx来处理。 1000100111011000 → 89D8H(数据) 1000100111011000 → mov ax,bx(指令) 那么,CPU在什么时候把它看作数据?在什么时候把它看作指令呢?这个在后面会讲到 存储器被划分成若干个存储单元,每个存储单元从0开始顺序编号,例如一个存储器有128个存储单元,编号从0~127,见 下图: file:///C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\ksohtml\wps3A1.tmp.png 那么一个存储单元能存储多少信息呢?我们知道计算机的最小信息单位是bit,也就是一个二进制位,8个bit组成一个Byte, 也就是通常讲的一个字节,微型机存储器的一个存储单元可以存储一个Byte,即8个bit(8个二进制位),一个存储器有128个 存储单元,它可以存储128个Byte。 微机存储器的容量是以字节为最小单位来计算的,对于拥有128个存储单元的存储器,我们可以说它的容量是128个字节。 对于大容量的存储器,一般还用以下单位来计量容量(以下用B代表Byte)。 1KB=1024B 1MB=1024KB 1GB=1024MB 1TB=1024GB 以上讲到,存储器被划分成多个存储单元,存储单元从0开始顺序编号,这些编号就是存储单元的内存地址,见下图: file:///C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\ksohtml\wps3A2.tmp.png CPU要从内存中读取或写入数据,首先要指定内存地址,并指明要对哪一个器件进行操作,是读取数据还是写入数据,因而, CPU要想进行数据的读写,必须和外部器件的芯片进行下面3类信息的互交: 1:内存地址(地址信息) 2:器件的选择,读或写命令(控制信息) 3:读或写的数据(数据信息) 那么CUP是通过什么将地址、数据和控制信息传到内存中呢?是导线,是连接CPU和其他芯片的导线,通常称之为总线。 根据传送信息的不同,总线从逻辑上分为3类:地址总线、控制总线、数据总线。 CPU从内存3读取数据的过程如下图: file:///C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\ksohtml\wps3A3.tmp.png 1:CPU通过地址线将地址信息3发出。 2:CPU通过控制线发出内存读命令,选中存储器芯片,并通知它,将要从中读取数据。 3:存储器将内存地址3中的数据8通过数据线送入CPU。 写入数据的过程和读取数据的过程相似。如向内存地址3写入数据26: 1:CPU通过地址线将地址信息3发出。 2:CPU通过控制线发出内存写命令,选中存储器芯片,并通知它,将要从中写入数据。 3:CPU通过数据线将数据26送入内存地址3的存储单元中。 从上面我们知道了CPU是如何进行数据读写的,可是,如何命令计算机进行数据的读写呢?那要向它输入能够驱动它进行工 作的机器指令。 对于8086CPU,下面的机器指令就能够完成从内存地址3的存储单元读取数据。 机器指令:101000000000001100000000 汇编指令:mov ax,[3] 含义:从内存地址3的存储单元读取数据送入寄存器ax中。
|