8086 汇编王爽 第三章笔记:
这章节标题是
寄存器(内存访问)
根据上次提过的 汇编程序员能用指令读写的部件只有 CPU .汇编语言核心就是汇编指令,这些指令是被编译器这玩意翻译成 机器码,然后被CPU执行前面介绍了很多计算机CPU相关的基础知识。
本节课目标: 从内存的角度继续学习几个寄存器
前言知识点: CPU 在操作其他部件的时候,把它们都当做内存来对待,把它们总的看做一个由若干存单元组成的逻辑存储器,这个逻辑存储器就是我们所说的内存地址空间。
CPU 要进行数据读写,先寻址,找到器件,读或者写(控制信息),然后才是搞数据信息。寻址找的是内存地址空间,确定是那个单元后才得到地址或者改变地址上的数据。
8086 CPU 中,寄存器都是 16 位的,可以存储一个字(一个字单位长度等于两个字节单位长度数据),对于内存地址上的数据,可以改写或者获得一个字大小的单元数据,也就是两个字节的内容。
通用寄存器可以分为 高 低 的两个寄存器,分别存放高 8 位,低 8 位的数据,也就是分别是一个字节。
本节知识点归纳:
***单位一词是一个要点:
存储器上一个内存单元存放一个字节的大小。
内存单是有顺序的,低地址到高地址这么看的话,
比如:
某段地址空间上 0~3 编号的单元(共4个单元长度)的数据为 : 20H 4EH 12H 00H ; 在 debug 指令中用 -d 指令查看某个内存单元的数据时,都是 16 进制数据,而且不带 H 的。
读取0号地址数据到ax寄存器中时应该:
(ax) = 4E20H ,寄存器展示的时候是从高到低的顺序展示的二进制,这个值对应十进制为 2000
这里有必要阐明一下一个词:
字单元: 即存放一个字形数据(16位长度)的内存单元,由两个地址连续的内存单元组成。
– – 高地址内存单元存放字形数据的高位字节,低地址内存单元中存放字形数据的低位字节,
以后将: 起始地址为 N 的字单元简称为 N 地址字单元。
比如: 某个字单元由某个段上的 2,3 编号的两个内存单元组成,则这个字单元的起始地址为 2 ,我们可以说这是 2 地址字单元。
说明一下: “某个段” 这个词书上可没这么说,但是CPU找地址的时候总是 “段:偏” 这样定位到某个内存单元,而 这两个值都在对应的寄存器中去找,然后才开始操作单元的后面的地址上的数据,
‘偏’的值放在一个寄存器中,'段’的值也放在某个段寄存器,基于这种形式,常见的是让,段寄存器值不变,存放 ‘偏’ 值的 寄存器,在使用时自增一个值,这样就选在下一个内存单元位置,然后根据指令操作上面的值
这就意味着,当我们想要描述的时候,都是 先定位一下,然后以这个位置段地址为基地址,偏移开始编号,这么去定位。
存入寄存器中的数据也应该遵循; 我们获取的数据长度也是随着寄存器长度变化,其实编译器帮我们处理了长度
比如:ax 长度为 16 ,使用 mov ax,某个地址位置时 ; ax 应该存放的是那个地址上的 16 位长度(也就是一个字大小)
比如:ah 长度为 8 ,使用 mov ah,某个地址位置时 ; ah 应该存放的是那个地址上的 8 位