zoukankan      html  css  js  c++  java
  • 寄存器(内存访问)

    1.字数据在内存中的存放、内存单元地址

    CPU中,用16位寄存器来存储一个字。高八位存放高位字节,低八位存放低位字节。在内存中存储时,由于内存单元时字节单元(一个单元存放一个字节),则一个字要用两个地址连续的内存单元来存放,这个字的低位字节存放在低地址单元中,高位字节存放在高地址单元中。我们提出字单元的概念:字单元,即存放一个字型数据(16位)的内存单元,由两个地址连续的内存单元组成。高地址内存单元中存放字型数据的高位字节,低地址内存单元中存放字型数据的低位字节。

    2.数据在内存个CPU直接的传送

    我们用mov指令在寄存器和内存之间进行字节型数据的传送。因为8086CPU是16位结构,有16根数据线,所以,可以一次性传送16位的数据,也就是说可以一次性传送一个字。只要在mov指令中给出16位的寄存器就可以进行16位数据的传送了。

    我们知道,mov指令可以有以下几种形式。

    mov 寄存器,数据

    mov 寄存器,寄存器

    mov 寄存器,内存单元

    mov 内存单元,寄存器

    mov 段寄存器,寄存器

    add和sub

    add 寄存器,数据

    add 寄存器,寄存器

    add 寄存器,内存单元

    add 内存单元,寄存器

    sub 寄存器,数据

    sub 寄存器,寄存器

    sub 寄存器,内存单元

    sub 内存单元,寄存器

    操作数是内存单元时,指令中只给出[偏移地址],默认,[段地址]在ds中。

    3.[段]的概念,数据段,代码段,栈段的意义所指

     [段]是8086位解决用16位寄存器表示20位的物理地址而引入的一个逻辑上的概念。可以根据需要,将地址连续、起始物理地址为16倍数的一组内存单元(不超过64KB)当作一个[段]使用。

    在编程中,可以根据需要,将一组内存单元定义为一个段。我们可以将一组长度为N(N<=64KB)、地址连续、起始地址为16的倍数的内存单元当作专门存储数据的内存单元,从而定义了一个数据段。

    [栈]是一个逻辑上的概念。可以将一段内存空间当作[栈]来使用。

    用作数据段时,要把段地址给DS

    用作栈段时,要把段地址给SS,栈顶偏移地址给SP

    用作代码段时,段地址给CS,要取的指令偏移地址给IP。但cs和ip的值不能使用mov改变。

    4.[栈]的机制;与栈操作相关的寄存器SS和SP;与[栈]操作相关的指令push和pop;

    SS:栈段段寄存器,用于存放栈段的[段地址]

    SP:栈指针寄存器,用于存放栈顶的偏移地址

    5.寄存器DS的用途

    DS:数据段段寄存器,用于存放数据段的[段地址]

    将一段内存用作数据段,是编程时的一种安排

    在mov,add,sub等汇编指令中,访问内存单元时,默认情况下,指的是数据段。

  • 相关阅读:
    堆排序
    理解KMP算法
    C++性能提升
    论文阅读 | Pre-trained Models for Natural Language Processing: A Survey
    模型融合
    论文阅读 | COMPRESSING BERT: STUDYING THE EFFECTS OF WEIGHT PRUNING ON TRANSFER LEARNING
    论文阅读 | Compressing Large-Scale Transformer-Based Models: A Case Study on BERT
    沉淀再出发:关于netty的一些理解和使用
    沉淀再出发:mongodb的使用
    沉淀再出发:ElasticSearch的中文分词器ik
  • 原文地址:https://www.cnblogs.com/byxy/p/9922741.html
Copyright © 2011-2022 走看看