汇编语言(王爽) 一

来源:互联网 发布:淘宝精品服饰广告案例 编辑:程序博客网 时间:2024/06/02 05:15

汇编语言发展至今,有以下3类指令组成。

汇编指令:机器码的助记符,有对应的机器码。

伪指令:没有对应的机器码,由编译器执行,计算机并不执行。 

其他符号:如+、_、*、/等,由编译器识别,没有对应的机器码。

指令和数据

       指令和数据是应用上的概念。在内存或磁盘上,指令和数据没有任何区别,都是二进制信息。CPU在工作的时候把有的信息看作指令,有的信息看作数据,为同样的信息赋予了不同的意义。就像围棋的棋子,在棋盒里的时候没有任何区别,在对弈的时候就有了不同的意义。

       例如,内存中的二进制信息1000100111011000,计算机可以把它看作大小为89D8H 的数据来处理,也可以将其看作指令movax,bx来执行。

1000100111011000  -> 89D8H (数据)

1000100111011000  -> mov ax,bx (程序)

CPU对存储器的读写

        CPU要从内存中读数据,首先要指定存储单元的地址。也就是说它要先确定它要读取哪一个存储单元中的数据。就像在一条街上找人,先要确定他住在哪个房子里。
       另外,在一台微机中,不只有存储器这一种器件。CPU在读写数据时还要指明,它 要对哪一个器件进行操作,进行哪种操作,是从中读出数据,还是向里面写入数据。
       可见,CPU要想进行数据的读写,必须和外部器件(标准的说法是芯片)进行下面3类 信息的交互。

• 存储单元的地址(地址信息);

• 器件的选择,读或写的命令(控制信息);

• 读或写的数据(数据信息)。

       那么CPU是通过什么将地址、数据和控制信息传到存储器芯片中的呢?电子计算机能处理、传输的信息都是电信号,电信号当然要用导线传送。在计算机中专门有连接 CPU和其他芯片的导线,通常称为总线。总线从物理上来讲,就是一根根导线的集合。 根据传送信息的不同,总线从逻辑上又分为3类,地址总线、控制总线和数据总线。

CPU从3号单元中读取数据的过程(见图1.3)如下。

(1) CPU通过地址线将地址信息3发出。

(2) CPU通过控制线发出内存读命令,选中存储器芯片,并通知它,将要从中读取数据。

(3) 存储器将3号单元中的数据8通过数据线送入CPU。

写操作与读操作的步骤相似。如向3号单元写入数据26。

(1) CPU通过地址线将地址信息3发出。

(2) CPU通过控制线发出内存写命令,选中存储器芯片,并通知它,要向其中写入数据。

(3) CPU通过数据线将数据26送入内存的3号单元中。

从上面我们知道了CPU是如何进行数据读写的。可是,如何命令计算机进行数据的读写呢?

        要让一个计算机或微处理器工作,应向它输入能够驱动它进行工作的电平信息(机器码)。 对于8086CPU,下面的机器码,能够完成从3号单元读数据。

机器码: 101000010000001100000000

含义: 从3号单元读取数据送入寄存器AX

CPU接收这条机器码后将完成我们上面所述的读写工作。

机器码难于记忆,用汇编指令来表示,情况如下。

机器码: 10100001 00000011 00000000

对应的汇编指令:MOV AX,[3]

含义: 传送3号单元的内容入AX

地址总线

       现在我们知道,CPU是通过地址总线来指定存储器单元的。可见地址总线上能传送 多少个不同的信息,CPU就可以对多少个存储单元进行寻址。
       现假设,一个CPU有10根地址总线,让我们来看一下它的寻址情况。我们知道,在电子计算机中,一根导线可以传送的稳定状态只有两种,高电平或是低电平。用二进制表示就是1或0,10根导线可以传送10位二进制数据。而10位二进制数可以表示多少个不同的数据呢? 2的10次方个。最小数为0,最大数为1023。
       图1.4展示了一个具有10根地址线的CPU向内存发出地址信息11时10根地址线上传送的二进制信息。考虑一下,访问地址为12、13、14等的内存单元时,地址总线上传 送的内容是什么?
       一个CPU有N根地址线,则可以说这个CPU的地址总线的宽度为N。这样的CPU最多可以寻找2的N次方个内存单元。

数据总线

       CPU与内存或其他器件之间的数据传送是通过数据总线来进行的。数据总线的宽度决定了 CPU和外界的数据传送速度。8根数据总线一次可传送一个8位二进制数据(即一个字节)。16根数据总线一次可传送两个字节。
       8088CPU的数据总线宽度为8,8086CPU的数据总线宽度为16。我们来分别看一下它 们向内存中写入数据89D8H时,是如何通过数据总线传送数据的。图1.5展示了8088CPU 数据总线上的数据传送情况;图1.6展示了 8086CPU数据总线上的数据传送情况。

       8086有16根数据线,可一次传送16位数据,所以可一次传送数据89D8H;而8088只有8根数据线,一次只能传8位数据,所以向内存写入数据89D8H时需要进行两次数据传送。

控制总线

       CPU对外部器件的控制是通过控制总线来进行的。在这里控制总线是个总称,控制总线是一些不同控制线的集合。有多少根控制总线,就意味着CPU提供了对外部器件的多少种控制。所以,控制总线的宽度决定了 CPU对外部器件的控制能力。
       前面所讲的内存读或写命令是由几根控制线综合发出的,其中有一根称为“读信号输出”的控制线负责由CPU向外传送读信号,CPU向该控制线上输出低电平表示将要读取 数据;有一根称为“写信号输出”的控制线则负责传送写信号。

0 0
原创粉丝点击