学号:20171308150 姓名:江漪雯 班级:17计科4班

一、 内存中字的存储

1. 8086CPU中,用16位寄存器来存储一个字。高8位存放高位字节,低8位存放低位字节。
2. 在内存中存储时,由于内存单元是字节单元(一个单元存放一个字节),则一个字要用两个地址连续的内存单元来存放,这个字的低位字节存放在低地址单元中,高位字节存放在高地址单元中。
3.字单元:存放一个字型数据(16位)的内存单元,由两个地址连续的内存单元组成。高地址内存单元中存放字型数据的高位字节,低地址内存单元中存放字型数据的低位字节。
4.在以后的过程中,将起始地址为N的字单元简称为N地址字单元。

值得注意的是:字节型数据占1个单元,字型数据占2个连续的内存单元。我们通常使用字型数据单元(字单元)。

二、DS和 [address]
1. 8086CPU中的DS寄存器,通常用来存放要访问数据的地址。例如我们读取10000H单元的内容,代码如下:
mov bx,1000H
mov ds,bx
mov al,[0]
2. mov指令功能:
1)  将数据直接送入寄存器
2)  将某个寄存器中的内容送入另一个寄存器中
3)  将一个内存单元中的内容送入一个寄存器中
格式:
mov 寄存器名 内存单元地址(偏移地址,段地址在DS中),[]说明操作对象的源地址是一个内存单元,8086CPU会自动取ds中的数据位内存单元的段地址。
3. 由于8086CPU硬件设计的缘故,它不支持用mov指令将地址数据直接写到段地址寄存器中,只能先写到某个通用寄存器中,然后再写到段地址寄存器中。

三、字的传送
将寄存器中的值写入到内存单元中:
mov bx,1000H
mov ds,bx
mov ax,[0] ;1000:0处的字型数据送入ax
mov [0],cx  ;cx中的16位数据送到1000:0处
四、mov、add、sub指令
1.         mov 指令的几种形式:
1)        mov 寄存器,  数据       如:mov ax,8
2)        mov 寄存器,  寄存器     如:mov ax,bx
3)        mov 寄存器,  内存单元   如:mov ax,[0]
4)        mov 内存单元,寄存器     如:mov [0],ax
5)        mov 段寄存器,寄存器     如:mov ds,ax
6)        mov 寄存器,段寄存器        如:mov ax,ds
7)        mov 内存单元,段寄存器     如:mov [0],cs
8)        mov 段寄存器,内存单元     如:mov cs,[0]
2.         add和sub指令同mov一样,都有两个操作对象:
1)        add 寄存器,数据                       如:add ax,8
2)        add 寄存器,寄存器             如:add ax,bx
3)        add 寄存器,内存单元                如:add ax,[0]
4)        add 内存单元,寄存器                如:add [0],ax
5)        sub 寄存器,数据          如:sub ax,9
6)        sub 寄存器,寄存器             如:sub ax,bx
7)        sub 寄存器,内存单元          如:sub ax,[0]
8)        sub 内存单元,寄存器      如:sub [0],ax
五、数据段
1.     对于8086CPU机,在编程时,可以根据需要,将一组内存单元定义为一个段。我们可以将一组长度为N(N<=64KB)、地址连续、起始地址为16的倍数的内存单元当做专门存储数据的内存空间,从而定义了一个数据段。
2.    将一段内存当做数据段,是我们在编程时的一种安排,可以在具体操作的时候,用ds存放数据段的段地址,在根据需要,用相关指令访问数据段中的具体单元。
六、栈
1.  栈是一种具有特殊的访问方式的存储空间,先进后出,后入先出。联想:在一个盒子内放书。
2.  栈有两个基本的操作:入栈PUSH和出栈POP。
七、CPU提供的栈机制
1. 现今的CPU中都有栈的设计,8086CPU也不例外。8086CPU提供相关的指令来以栈的方式访问内存空间。这意味着,在基于8086CPU编程的时候,可以将一段内存当做栈来使用。
2. 8086CPU提供入栈和出栈指令,最基本的两个是PUSH(入栈)和POP(出栈)。如:
push ax,将寄存器ax中的数据入栈,pop ax表示从栈顶取出数据到ax。对栈的操作都是以字为单位进行的。
3. 栈顶为低地址,也即是说栈增长方向是从高到低。在栈操作指令完成后,栈顶是指向有数据的(栈为空时例外)。
4. 8086CPU中,有两个寄存器,段寄存器SS和寄存器SP,栈顶的段地址存放在SS中,偏移地址存放在SP中,任意时刻,SS:SP指向栈顶元素。
5. push指令和pop指令执行时,CPU从SS和SP中得到栈顶的地址。
6. push ax的执行过程:
1) SP=SP-2,SS:SP指向当前栈顶前面的单元,以当前栈顶前面的单元为新的栈顶
2) 将ax中的内容送入SS:SP指向的内存单元处,SS:SP此时指向新栈顶。
7. pop ax的执行过程:
1) 将SS:SP指向的内存单元处的数据送入ax中。
2) SP=SP+2,SS:SP指向当前栈顶下面的单元,以当前栈顶下面的单元为新的栈顶。
八、栈顶超界的问题
1. 栈顶超界既可以发生在入栈时,也可以发生在出栈时。
2. 栈顶超界是危险的,栈空间外的空间可能存放了有其他用途的数据、代码。如果在出栈入栈时不小心将这些数据、代码意外地改写,将会引发一连串的错误。
3. 8086CPU不保证我们对栈的操作不会超界。也就是说,8086CPU只知道栈顶在何处(由SS:SP指示),而不知道我们安排的栈空间有多大。类似的,CPU只知道当前要执行的指令在何处(由CS:IP指示),而不知道要执行的指令有多少。从这两点看出,8086CPU的工作机理,它只考虑当前的情况:当前的栈顶在何处、当前要执行的指令是哪一条。
4. 我们在编程的时候要自己操心栈顶超界的问题,要根据可能用到的最大栈空间,来安排栈的大小,防止入栈的数据太多而导致的超界;执行出栈操作的时候也要注意,以防栈空的时候继续出栈而导致的超界。
九、 push、pop指令
1. push和pop指令是可以在寄存器和内存单元之间传送数据的。
2. push和pop指令的格式可以是如下形式:
1) push 寄存器                pop 寄存器
2) push 段寄存器            pop 段寄存器
3) push 内存单元            pop内存单元

3.push,pop指令实质上就是一种内存传送指令,可以在寄存器和内存之间传送数据,与mov指令不同的是,push和pop指令访问的内存单元的地址不是在指令中给出的,而是由SS:SP指出的。同时,push和pop指令还要改变SP中的内容。

4. push和pop指令不同于mov指令,CPU执行mov指令只需一步操作,就是传送,而执行push、pop指令却需要两步操作。

转载于:https://www.cnblogs.com/jywe/p/9970624.html

第三章 寄存器(内存访问)相关推荐

  1. 汇编语言:第三章 寄存器(内存访问)

    3.1内存中字的存储 CPU中寄存器是16位的,可以用高低字节存储一个字,但是每个内存单元是8位的,只能存储一个字节, 所以内存中用相邻2个内存单元存储一个字的高低字节 如:20000数值(4E20H ...

  2. 寄存器(内存访问)---汇编学习笔记

    寄存器(内存访问) 序言 第二章,我们主要从CPU如何执行指令的角度讲解了8086CPU的逻辑结构.形成物理地址的方法.相关的寄存器以及一些指令. 这一章,我们从访问内存的角度继续学习几个寄存器. 3 ...

  3. Java并发编程 - 第三章 Java内存模型

    前言: Java 线程之间的通信对程序员完全透明,内存可见性问题很容易困扰 Java 程序员,本章将揭开 Java 内存模型神秘的面纱. 一.Java 内存模型的基础 1.1 并发编程模型的两个关键问 ...

  4. mysql 访问寄存器_汇编寄存器(内存访问)基础知识之三---mov指令

    1 内存中字的存储 一个字型数据占2个内存单元,内存里面一个内存单元一个字节(8位),高地址单位放高8位,低地址单元放低8位. 注意:0号是地址单元,1是高地址单元(上是低地址,下面是高地址) (1) ...

  5. 第三章 JVM内存回收区域+对象存活的判断+引用类型+垃圾回收线程

    注意:本文主要参考自<深入理解Java虚拟机(第二版)> 说明:查看本文之前,推荐先知道JVM内存结构,见<第一章 JVM内存结构> 1.内存回收的区域 堆:这是GC的主要区域 ...

  6. 【操作系统】第三章:内存管理

    文章目录 3.1.1 内存的基础知识 什么是内存?有何作用 指令的工作原理 进程装入内存的三种方式 从写程序到程序运行 3.1.2 内存管理的概念 内存空间的分配与回收 内存空间的扩展 地址转换 内存 ...

  7. 《数据密集型计算和模型》第三章_内存计算复习

    <数据密集型计算和模型>第三章的有关内容.主要有内存计算的概念.内存计算的硬件结构.内存计算的系统软件.内存数据库等相关内容. 文章目录 一.内存计算的概念 1. 为什么需要内存计算? 2 ...

  8. 操作系统——第三章(内存管理)

    内存 内存是用于存放数据的硬件,程序执行前需要先被放到内存中才能被CPU处理. 进程运行的基本原理: 编辑源代码文件 然后进行编译,由源代码文件生成目标模块,此时高级语言被翻译为机器语言 链接:由目标 ...

  9. 汇编语言学习-寄存器(内存访问)

    内存中字的存储: 两个16进制位是一个字节! 0号单元是低地址单元,1号单元是高地址单元. 0地址单元中存放的字节型数据是多少? 注意区别:"0地址单元"指向的就是:20H 0地址 ...

最新文章

  1. 完全平方数(打表+二分)
  2. 远程桌面中Tab键不能补全的解决办法
  3. 聚焦AI落地痛点,纵论跨域学习技术前沿和应用趋势 | CNCC技术论坛
  4. android 退出程序解决内存释放so的问题
  5. CodeForces - 1096D Easy Problem(线性dp)
  6. python文件,字符串,二进制的读写
  7. 是介于小型机和微型计算机,第一章计算机基础解析.ppt
  8. 还在用 Random生成随机数了?试试 ThreadLocalRandom,好用!
  9. Web架构演变过程以及出现的问题
  10. MSN QQ在线聊天代码
  11. ThinkPad E430 选择U盘启动后又跳回选择画面
  12. 【Matlab水果蔬菜识别】灰度+二值化+腐蚀+直方图处理水果蔬菜识别【含GUI源码 1052期】
  13. 静无止静,澎湃聆听——飞利浦T4507降噪真无线耳机上市
  14. **sony Wi-H700通话质量非常差的原因分析**
  15. 04-原始模型模式Quarkus实现
  16. 天猫双11背后的阿里技术
  17. 账号联合运营--花漾指纹浏览器引领跨境电商新趋势
  18. c++ eos智能合约开发_EOS开发完全解析(六):手摸手实现第一个EOS智能合约——Hello EOS...
  19. 六级(2020/12-2) Section A
  20. Linux复制文件夹

热门文章

  1. python中oxf2是多少_python 函数基础2
  2. python自动化测试环境搭建_(一)Python+Appium自动化测试环境搭建
  3. oracle中的中文排序,Oracle中的中文排序方式
  4. gpu云服务器运行游戏_滴滴云不甘寂寞,国内首发一款GPU云服务器
  5. iphone换机数据迁移_怎么一键换机?换新机迁移数据必看教程!
  6. zabbix的入门与配置
  7. eclipse或Myeclipse中web项目没有run on server时怎么办?
  8. leetcode--57--Insert Interval
  9. 4G、5G难配物联网 hold不住也得死撑
  10. golang 锁的使用