(重编)《汇编语言(第三版)》笔记(二) - 寄存器

2017年6月19号重编,完善思维导图。
2017年8月12号重编,完善思维导图。

// 监测点 1.1 答案
1.答案:13
  解析:8KB = 8*1024 Byte = 2的13次方 Byte  
        因为每个内存单元是1 Byte,所以地址总线就是13根。
2.答案:1KB 的存储器有 1024 个存储单元。存储单元的编号从 0 到 1023。
3.答案:1KB 的存储器可以存储 1024*8 个 bit,1024 个 Byte。
4.答案:1GB、1MB、1KB 分别是 2^30、2^20、2^10 Byte。(n^m 的意思是 n 的 m 次幂) 
5.答案:8080、8088、80286、80386 的地址总线宽度分别是 16 根、20 根、24 根、32 根,则它们的寻址能力分别为:64(KB)、1(MB)、16(MB)、4(GB)。 
6.答案:8080、8088、8086、80286、80386 的数据总线宽度分别为 8 根、8 根、16 根、 16 根、32 根。则它们一次可以传送的数据为:1(B)、1(B)、2(B)、2(B)、4(B)。 
7.答案:从内存中读取 1024 字节的数据,8086 至少要读 512 次、80386 至少要读 256 次。
8.答案:在存储器中,数据和程序以二进制形式存放。
Snip20170812_4.png

第二章:寄存器

  • 一个 CPU 基本由:运算器、控制器、寄存器等器件构成,靠内部总线相连。
    • 运算器进行信息处理
    • 寄存器进行信息存储
    • 控制器控制各种器件进行工作
    • 内部总线连接各种器件,在数据传递
  • 对于程序员来讲,主要部件是寄存器,寄存器是程序员可以用指令读写的部件。
  • (了解)8086CPU(一个古老的CPU)有 14 的寄存器:AX,BX,CX,DX,SI,DI,SP,BP,IP,CS,SS,DS,ES,PSW。

1.通用寄存器

  • 8086CPU的所有寄存器都是 16 位的,可以存放两个字节(一个字节 8 位)。
  • AX,BX,CX,DX这 4 个存储器通常放一般性的数据,被称为通用寄存器。
Snip20170529_1.png
  • 一个 16 位寄存器可以存储一个 16 位的数据,最大值为 2的16次方 - 1
  • 8086CPU的上一代 CPU 中的寄存器都是 8 位,为了保证兼容,AX,BX,CX,DX都可以分为两个独立使用的 8 位寄存器。
  • AX 可分为 AH(height) 和 AL(low)。
  • BX 可分为 BH(height) 和 BL(low)。
  • CX 可分为 CH(height) 和 CL(low)。
  • DX 可分为 DH(height) 和 DL(low)。
Snip20170529_3.png

2.字在寄存器中的存储

  • 出于兼容新考虑,8086CPU可以一次性处理两种尺寸的数据
  • 字节(byte):一个字节由 8 个 bit 组成,存在 8 位寄存器中。
  • 字(word):一个字由两个字节组成,分别称为高位字节、低位字节。
Snip20170529_2.png
Snip20170530_10.png

3.几条汇编指令

  • 一条汇编指令或一个寄存器的名称不区分大小写。
Snip20170530_4.png
  • 练习:请计算一下下面表格的结论.
Snip20170530_7.png
  • (在第三行卡住了,才知每一行的结论都是相关连的。😅)
  • (其次:mov ax, 001AH,001AH不要想当然就是bx。)
Snip20170530_8.png
  • 练习:请计算一下下面表格的结论.
Snip20170530_9.png
Snip20170530_13.png
  • 系统自带的计算器都有进制转换的功能,请结合计算。
Snip20170601_3.png
  • 答案在下一期

4.物理地址

  • 所有内存单元构成的存储空间是一个一维的线性空间,每一个内存单元在空间中都有唯一的地址(物理地址)。
  • 在 CPU 向地址总线上发出物理地址之前,必须要在内部先形成物理地址。

5.16位结构的CPU

  • 8086CPU是 16 位机(16 位结构的CPU)
  • 运算器一次最多可以处理16位数据
  • 寄存器的最大宽度为 16 位
  • 寄存器和存储器之间的通路为 16 位

6.8086CPU给出的物理地址的方法

  • 8086CPU 有 20 位地址总线,可以传送 20 位地址,达到 1MB (1MB=1024x1024=2的20次方)寻址能力
  • 8086CPU 又是 16 位结构,在内部一次性处理、传输、暂时存储的地址为 16 位。
  • 从内部结构看:简单的发出只能送出 16 位的地址,表现出 64KB 的选址能力。
  • 8086CPU 采用一种在内部用两个 16 位地址合成的方法来形成一个 20 位的物理地址。
Snip20170615_7.png
  • 地址加法器采用物理地址=段地址x16+偏移地址的方法用段地址和偏移地址合成物理地址。
  • 例如,8086CPU 要访问地址为123C8H的内存单元,过程如下:
Snip20170615_8.png
Snip20170615_10.png
  • 个人理解

  • 结合上面两张图,再结合计算,我起初还不明白,1230x16=12300?``WHY?

  • 通过计算和对第二张图的理解

Snip20170615_11.png
Snip20170615_12.png
  • 图中二进制向左移了四位
  • 集合上图中结论:一个 X 进制的数据左移 1 位,相当于乘以 X。
  • 我一个一个的乘以2,发现确实等于 12300
  • 突然知道,16 是十进制的,转换成 16 进制是 10 😅。
  • 结论:16 要转换成相同进制再计算。
  • 结论:十六进制的段地址 x16,结果就是加一个 0.

7.“物理地址=段地址x16+偏移地址”的本质含义

  • 本质含义:CPU 在访问内存时,用一个基础地址(段地址x16)和一个相对于基础地址的偏移地址相加,给出内存单元的物理地址。
  • 段地址x16可以看作是基础地址。

8.段的概念

  • 内存并没有分段,段的划分来自于 CPU,由于 8086CPU 用 "物理地址=基础地址(段地址x16)+偏移地址" 的方式给出内存单元的物理地址,我们可以用分段的方式来管理内存。
  • 偏移地址为 16 位,16 位地址的寻址能力为 64K,所以一个段的长度最大为 64K 。
Snip20170615_14.png
Snip20170615_16.png
Snip20170615_17.png
  • 答案见下回

9.段寄存器

  • 段地址在 8086CPU 的段寄存器中存放。
  • 8086CPU 有 4 个段寄存器:CS(代码段寄存器)、DS(数据段寄存器)、SS(堆栈段寄存器)、ES(附加段寄存器,前面几个放不下,就放在这里)
  • 当 8086CPU 要访问内存时由这 4 个段寄存器提供内存单元的段地址。

10.CS和IP

  • CS 和 IP 是 8086CPU 中两个最关键的寄存器,它们指示了 CPU 当前要读取指令的地址。
  • CS 为代码段寄存器,IP 为指令指针寄存器。
  • 8086CPU 中任意时刻,CPU 将 CS:IP 指向的内容当作指令执行
Snip20170615_29.png
未命名xx.gif
  • 读取一条指令后,IP 中的值自动增加,以使 CPU 可以读取下一条指令。当前读入的指令 B82301
  • 1.从 CS:IP 指向的内存单元读取指令,读取的指令进入指令缓冲器;
  • 2.IP = IP + 所读指令的长度,从而指向下一条指令;
  • 3.执行指令。转到步骤(1),重复这个过程。
  • CS 和 IP 的内容提供了 CPU 要执行指令的地址。
Snip20170617_2.png

11.修改 CS、IP 的指令

  • 在 CPU 中,程序员能够用指令读写的部件只有寄存器,程序员可以通过改变寄存器中的内容实现对 CPU 的控制。CPU 从何处执行指令是由 CS、IP 中的内容决定的,程序员可以通过改变 CS、IP 中的内容来控制执行目标指令。
  • mov:传送指令,不能用于设置 CS、IP 的值。
  • 转移指令:能够改变 CS、IP 的内容的指令
  • jmp:一个最简单的可以修改 CS、IP 的指令

jmp 2AE3:3,执行后:CS=2AE3HIP=0003HCPU 将从 2AE33H 处读取指令。

  • "jmp 段地址:偏移地址" 指令的功能为:用指令中给出的段地址修改 CS,偏移地址修改 IP。
  • "jmp 某一合法寄存器" 指令的功能为:用寄存器中的值修改 IP。
Snip20170617_13.png

12.代码段

Snip20170617_14.png
Snip20170617_17.png
Snip20170617_19.png

实验 1 查看 CPU 和内存,用机器指令和汇编编程

  • 步骤见下期
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • 8086汇编 本笔记是笔者观看小甲鱼老师(鱼C论坛)《零基础入门学习汇编语言》系列视频的笔记,在此感谢他和像他一样...
    Gibbs基阅读 37,106评论 8 114
  • 王爽汇编全书知识点大纲 第一章 基础知识 机器语言 汇编语言的产生 汇编语言的组成 存储器 cpu对存储器的读写 ...
    2c3ba901516f阅读 2,404评论 0 1
  • 根据馒头商学院制订的2017年全年学习计划,以及自己的工作实际,选取了一部分书籍进行阅读和学习,每个月一个主题,自...
    姑苏公子阅读 150评论 0 0
  • 许余把自己的签名改成了“相见不如怀念”。改过之后,她知道有些事情再也不能回到过去了,以后有的也只是回忆。 她从抽屉...
    迟一木阅读 593评论 6 10
  • 慢慢的,我们都过了爱做梦的年纪。
    那些内心的声音阅读 189评论 0 0