第2章——寄存器

一个典型的CPU由运算器、控制器、寄存器等器件构成,这些器件靠内部总线相连。前一章所说的总线,相对于cpu内部来说是外部总线。内部总线实现内部各个器件之间的联系,外部总线实现CPU和主板上其他器件的联系。简单的说,在CPU内部:

.运算器进行信息处理

.寄存器进行信息存储

.控制器控制各种器件进行工作

.内部总线链接各个器件,在它们之间进行数据的传送

寄存器是CPU中程序员可以用指令读写的部件。不同的CPU,寄存器个数、结构是不相同的。8086CPU有14个寄存器,分别是:AX,BX,CX,DX,SI,DI,SP,BP,IP,CS,SS,DS,ES,PSW.

.通用寄存器

8086CPU是16位的,可以存放两个字节。AX,BX,CX,DX这四个寄存器通常用来存放一般性的数据,称为通用寄存器。为了与8086CPU上一个版本8位CPU的寄存器兼容,8086的这四个通用寄存器可以分为两个独立使用的8位寄存器来使用:AX可以分为AH和AL、AL表示低8位,AH表示高8位,同理其他三个寄存器也是一样。

.字在寄存器中的存储

字节:记为Byte,等于8bit

字:记为word,等于2个字节。

一个数0100 1110 0010 0000可以看做一个字,十进制为2000,也可以分别看做两个字节,一个78,一个32.在以后的介绍中,以H结尾表示16进制数据。

.几条汇编指令

在写一条汇编指令或者寄存器的名字时,不区分大小写。

例如:mov ax,18和MOV AX,18 含义相同。

mov ax,18 ;相当于ax=18

mov ax,bx;相当于ax=bx

add ax,8;相当于ax=ax+8

add ax,bx;相当于ax=ax+bx

eg:

mov ax,8226H

mov bx,ax

add ax,bx

最后ax为044CH,ax和bx的数据都是8226H,相加之后得到1044CH,但是ax是16位的寄存器,只能存放4位十六进制数,所以最高位1不能保存在ax中,故最后ax为04CCH。

mov ax,00C5H

add al,93H

最后ax的数据为0058H。C5H+93H等于158H,但是al是8位的,最高位1丢失,最后ax为0058H。(这里的丢失,指的是进位值不能在8位寄存器中保存,但是CPU并不真正的丢弃这个值,关于这个问题,我们在之后的课程中讨论)。注意,此时al作为一个独立的寄存器来使用,与ah没有关系,不要认为进位会存储在ah中。在进行数据传送或运算时,要注意两个操作对象的位数应该是一致的,否则是错误的。例如:mov ax,al;这是错误的,al和ax寄存器的位数不同。

课后一练:

只使用目前学过的汇编指令,最多使用4条指令,计算2的4次方是多少?

Q:

mov ax,2

mov ax,ax

mov ax,ax

mov ax,ax

时间: 2024-11-07 04:48:23

第2章——寄存器的相关文章

第二章 寄存器基础概念

第二章 寄存器 1.一个典型的CPU由运算器,控制器,寄存器等器件组成. 内部总线实现CPU内部各个器件之间的联系. 外部总线实现CPU和主板上其它器件的联系. 2.8086是Intel系列中16位微处理器,地址总线20位. 8086有14个16位寄存器:AX,BX,CX,DX,是通用寄存器SI,DI,BP,SP,是基址和变址寄存器CS,SS,DS,ES,是段寄存器IP,FLAGS是指令指针和标志寄存器. 3.通用寄存器:一个CPU有多个寄存器,用来存放十六位一般性数据 下面以AX为例 4.汇编

第二章 寄存器相关内容总结

对于一个汇编程序员来说,CPU中的主要部件是寄存器.寄存器是CPU中程序员可以用指令读写的部件.程序员通过改变各种寄存器中的内容来实现对CPU的控制.不同的CPU,寄存器的个数.结构是不相同的.8086CPU有14个寄存器,每个寄存器有一个名称. 8086CPU的所有寄存器都是16位的,可以存放两个字节.AX.BX.CX.DX.这4个寄存器通常用来存放一般性的数据,被称为通用寄存器.出于对兼容性的考虑,8086CPU可以一次性处理以下两种尺寸的数据.字节:记为byte,一个字节由8个bit组成,

第三章 寄存器(内存访问)相关内容总结

在本章中,我们从访问内存的角度继续学习了几个寄存器.我们提出字单元的概念:字单元,即存放一个字型数据(16位)的内存单元,由两个地址连续的内存单元组成.高地址内存单元中存放字型数据的高位字节,低地址内存单元中存放字型数据的低位字节.CPU要读写一个内存单元的时候,必须先给出这个内存单元的地址,在8086PC中,内存地址由段地址和偏移地址组成.8086CPU中有一个DS寄存器,通常用来存放要访问数据的段地址.我们用mov指令在寄存器和内存之间进行字节型数据的传送.因为8086CPU是16位结构,有

第三章 寄存器(内存访问)

在第五章的学习之后,因为实验课在老师的抽查之后发现前面的知识很多都忘了,便对之前的知识进行了一遍系统的复习,对汇编的基础知识基本都已经掌握,也有了更加深刻的认识. 在第三章中我们主要从内存访问的角度来继续学习CPU执行指令的原理,并进一步的学习上一章的寄存器. <1>内存中字的存储 字由高位字节和低位字节组成,用16位寄存器来存储.高八位存放高位字节,低八位存放低位字节.字需要两个地址连续的内存单元(一个字节)来存储,字的低位字节存放在低地址单元中,高位字节存放在高地址单元中.如下图,我们想要

汇编语言第三版 第二章 寄存器

问题1.8086CPU的地址总线为20bit,而数据总线为16bit--也就是说每次传输的数据为16bit,那么如何使用16bit的数据总线来实现20bit的地址总线的地址传输? 答:8086CPU使用两个16bit的地址合成一个20bit的物理地址. 16bit A: XXXX 16bit B: XXXX 20bit物理地址的合成 A *16 也就是将A(16进制表示的数值),向左移动一位,然后加上B.A * 16  +  B.物理地址 = 段地址 * 16 + 偏移地址 16bit A: X

王爽《汇编语言》第三版 第二章 寄存器

CPU概述 一个典型的CPU由运算器.控制器.寄存器等器件组成,这些器件靠内部总线相连. 内部总线实现CPU内部各个器件之间的联系,外部总线实现CPU和主板上其它器件的联系. 8086CPU有14个寄存器 它们的名称为:AX.BX.CX.DX.SI.DI.SP.BP.IP.CS.SS.DS.ES.PSW. 2.1 通用寄存器 8086CPU所有的寄存器都是16位的,可以存放两个字节. 8086上一代CPU中的寄存器都是8位的: 为保证兼容性,这四个寄存器都可以分为两个独立的8位寄存器使用. 1.

汇编语言(王爽) 第2章 寄存器

CPU由运算器,控制器,寄存器等器件组成 汇编指令可以操作寄存器中的数据.如mov AX,BX就是把寄存器BX中的值加上寄存器AX中的值,再把结果放在AX上 8086CPU的寄存器的有14个,这里就讲AX,BX,CX,DX,CS,IP这么几个先 2.1通用寄存器 就是指AX,BX,CX,DX 用来存放一般数据 如AX是16位,但是8086CPU之前的一代是8位的,所以AX分为AH,AL来兼容之前版本的数据 同理 BX,CX,DX.另外AH的H是high的意思,在左边高位,L是low的意思在右边是

汇编语言(王爽) 第3章寄存器(内存访问)

3.1 内存中的字 内存中的字是16位的,以2个内存单元存储 地址大的存高位(字的左边8位),地址小的存低位(字的右边8位) 字单元:存放1个字形数据的内存单元,由2个内存单元组成,共16位 3.2 DS 一个寄存器的名字,用来放数据段的段地址 mov 指令可以把数据转到寄存器,一个寄存器的内容转到另一个寄存器,内存单元(字单元)转到寄存器 但是一般会mov ax,1000h;mov ds,ax而不是直接mov ds,1000h 因为8086CPU不支持直接把内存单元的东西转到段寄存器上面 3.

第二章寄存器

寄存器有:AX,BX,CX,DX,SI,DI,SP,BP,IP,CS,SS,DS,ES,PSW等等 通用寄存器有AX.BX.CX.DX 8086又分为两个8位寄存器:AX = AH和AL,BX=BH和BL...等如下 监测点: F4A3 31A3 3123 6246 826C 6246 826C 04D8 0482 6C82 D882 D888 D810 6246 段地址:   段地址*16+偏移地址 =就是物理地址 段地址必须是16的倍数,偏移地址 监测点2.2 0010FH-1000FH 1