目录
引录
汇编语言是直接在硬件之上运作的编程语言,首先要了解硬件系统的结构,才能有效的应用汇编语言对其编程·。
汇编课程的研究重点放在如何利用硬件系统的编程结构和指令集有效灵活的控制系统进行工作。
最终运行程序的是CPU,我们用汇编编程的时候,必须要用CPU的角度考虑问题(核心思维)。
基础知识1
机器语言
- 机器语言是机器指令的集合。
- 机器指令展开来讲就是一台机器可以正确执行的指令。
早期的程序员们将0,1数字编程的程序代码打在纸带或卡片上(1打孔,0不打孔),再将程序通过纸带机或卡片机输入计算机,进行运算。
后来呢,逐渐使用高科技......但打洞洞是始祖~
机器码:一种二进制
汇编语言
汇编语言的主体是汇编指令。
汇编指令和机器指令的差别在于指令的表示方法上,汇编指令是机器指令便于记忆的书写格式。
汇编指令是机器指令的助记符。
例如:
机器指令:1000100111011000
操作:寄存器BX的内容送到AX中
汇编指令:MOV AX,BX
这样的写法与人类语言接近,便于阅读和记忆
汇编语言的产生
早期的程序员们发现使用机器语言很麻烦,因此,引入了汇编语言
寄存器:简单的讲是CPU中可以存储数据的器件一个CPU中有多个寄存器。AX是其中一个寄存器的代号,BX是另一个寄存器的代号。
有些代号存放数据,有些存放指令
计算机能读懂的只有机器指令,那么如何让计算机执行程序员用汇编指令编写的程序呢?
原理如图:
汇编语言的组成
- 汇编语言有以下3类组成:
- 汇编指令(直接翻译成机器码的--机器码的助记符)
- 伪指令 (由编译器执行)
- 其他符号 (由编译器执行)
实际上,其他符号也可以算作是伪指令
汇编语言的核心是汇编指令,它决定了汇编语言的特性。
基础知识2
存储器
- CPU是计算机的核心部件,它控制整个计算机运作并进行运算,要想让一个CPU运作,就必须向它提供指令和数据。(大脑)
指令和数据在存储器中存放,也就是平所时说的内存。内存是其中一个主要的存储器。
在一台PC机中内存的作用仅次于CPU。
离开了内存,性能再好的CPU也无法工作。
磁盘不同于内存,磁盘上的数据或程序,如果不读到内存中,就无法被CPU使用
各类存储器芯片
从读写属性上看分为两类:
随机存储器(RAM)和只读存储器(ROM)
RAM:断电后数据将会遗失 就像内存
ROM:只读,但是数据一直保存在那里,除非刷掉
从功能和连接上分类:
随机存储器RAM
装有BIOS的ROM
接口卡上的RAM
BIOS:基本输入输出系统。
BIOS是由主板和各类接口卡(如显卡,网卡等)厂商提供的软件系统,可以通过它利用该硬件设备进行最基本的输入输出。在主板和某些接口卡上插有存储相应BIOS的ROM
CPU对它们进行读或写的时候都通过总线发出内存读写命令
指令和数据
指令和数据是应用上的概念
在内存或硬盘中,指令和数据没有任何区别,都是二进制信息
存储器被划分为若干个存储单元,每个存储单元从0开始顺序编号
例如:
一个存储器由128个存储单元,
编号0~127(从0开始)
对于大容量的存储器一般还用一下单位来计量容量(以下用B来代表Byte)
1KB = 1024B(2^10)
1MB = 1024KB
1GB = 1024MB
1TB = 1024GB
磁盘的容量单位同内存一样,实际上以上单位是微机中常用的计量单位。
内存地址空间
什么是内存地址空间?
一个CPU的地址线宽度为10,那么可以寻址1024个内存单元,这1024个可寻到的内存单元就构成这个CPU的内存地址空间。
首先需要介绍两部分基本知识,主板和接口卡。
主板
- 在每一台PC机中,都有一个主板,主板上有核心器件(CPU,内存等)和一些主要器件。
- 这些器件通过总线(地址总线,数据总线,控制总线)相连。
接口卡
- 计算机系统中,所有可用程序控制其工作的设备,必须受到CPU的控制。
CPU对外部设备不能直接控制,如像素器,音响,打印机等。直接控制这些设备进行工作的是插在扩展槽上的接口卡(显卡,网卡…)
CPU对存储器的读和写
CPU要想进行数据的读写,必须和外部器件(标准的说法是芯片)进行三类信息的交互:
- 存储单元的地址(地址信息)
- 器件的选择,读或写的命令(控制信息)
- 读或写的数据(数据信息)(读什么写什么)
那么CPU是通过什么将地址,数据和控制信息传到存储芯片中的呢?
电子计算机能处理,传输的信息都是电信号,电信号当然要用导线传送。
在计算机中专门有连接CPU和其他芯片的导线,通常称为在总线。
- 物理上:一根根导线的集合:
- 逻辑上划分为:
- 地址总线
- 数据总线
- 控制总线
总线在逻辑上划分的图示:
CPU怎么对存储器进行读写,从哪个总线过来的,就把它用哪个语句来算
对于8086CPU,下面的机器码能够完成从3号单元读数据:
机器码:101000000000001100000000
含义:从3号单元读取数据送入寄存器AX
CPU接收这条机器码后将完成上面所述的读写工作
为什么要用8086?我们把最简单的拆完了,因为它们的架构是一样的
1.地址总线
对一个存储单元操作,要知道它在哪里,只要放在地址总线上的数据,它都会变成一个地址,
CPU是通过地址总线来指定存储单元的。
地址总线上能够传送多少个不同的信息,CPU就可以对多少个存储单元进行寻址。
位(64位,32位)就是地址总线的线数
系统用的64位是不是地址总线就是64位呢?
不是的,要达到完全的64位,CPU要64位,其次要有一个64位的操作系统,接着要有一个64位的操作软件,缺一不可
地址总线是如何发送地址信息的呢?如下图
一个CPU有N根地址总线,则可以说这个CPU总线的宽度位N。
这样的CPU最多可以寻找2^N个内存单元(1Byte = 8bit)
2.数据总线
CPU与内存或其他器件之间的数据传送是通过数据总线来进行的。
数据总线的宽度决定了CPU和外界的数据传送速度。
16位数据总线上传送的信息,如图
3.控制总线
- CPU对外部器件的控制是通过控制总线来进行的。在这里控制总线是个总称,控制总线是一些不同控制线的集合。
- 有多少根控制总线,就意味着CPU提供对外部器件的多少种控制。
所以,控制总线的宽度决定了CPU对外部器件的控制能力。
- 控制总线发送控制信息
- 内存读或写命令是由几根控制线综合发出的:
- 其中有一根名为读信号输出控制线负责由CPU向外传送读信号,CPU先该控制线上输出低电平表示将要读取数据;
- 有一根名为写信号输出控制线赋值由CPU向外传送写信号。
小结
- 汇编指令是机器指令的助记符,同机器指令一一对应。
- 每一种CPU都有自己的汇编指令集。
- CPU可以直接使用的信息在存储器中存放。
- 在存储器中指令和数据没有任何区别,都是二进制信息。
- 存储单元从0开始顺序编号。
- 一个存储单元可以存储8个bit(用作单位写成“b”),即8位二进制数。
- 每一个CPU芯片都有许多管脚,这些管脚引出总线。一个CPU可以引出三种总线的宽度标志了这个CPU的不同方面的性能:
- 地址总线的宽度决定了CPU的寻址能力;
- 数据总线的宽度决定了CPU与其他器件进行数据传输时的一次数据传送量;
- 控制总线宽度决定了CPU对系统中其他器件的控制能力