汇编语言(王爽) 一
来源:互联网 发布:淘宝精品服饰广告案例 编辑:程序博客网 时间: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向该控制线上输出低电平表示将要读取 数据;有一根称为“写信号输出”的控制线则负责传送写信号。
- 汇编语言(王爽) 一
- 王爽 《汇编语言》 读书笔记 一 基础知识
- 汇编语言一
- 王爽 《汇编语言》学习笔记 (一)
- 8、王爽《汇编语言》笔记_子程序一
- 汇编语言 王爽(第三版)课程设计一
- 汇编语言笔记(一)
- 汇编语言学习笔记(一)
- 汇编语言学习一
- 汇编语言笔记(一)
- 汇编语言程序设计(一)
- 哈工大汇编语言实验一
- 汇编语言学习(一)
- 汇编语言学习(一)
- 8086汇编语言课程设计一
- 汇编语言()一
- 汇编语言基础-寄存器(一)
- 汇编语言一补充
- JavaScript Dom编程艺术 阅读笔记
- 迷宫问题 POJ - 3984
- 动态规划 DP
- html中隐藏域hidden的作用
- 学习笔记---main函数参数-动态存储管理与动态数组
- 汇编语言(王爽) 一
- js学习笔记
- 【t030】数字构造
- 【Python】URL深度采集+源码分析
- Git使用操作
- 博为峰Java技术文章 ——JavaSE Swing JScrollPane滚动条容器I
- spring bean的获得方式
- 积极应对认真调查Note7燃损原因 彰显企业担当
- Linux 孤儿、僵尸、服务进程创建