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