博客
关于我
微机原理 13-存储器寻址
阅读量:676 次
发布时间:2019-03-16

本文共 595 字,大约阅读时间需要 1 分钟。

8086存储器分段管理

8086处理器采用分段管理方式来处理存储器的地址空间。这种分段机制是由于8086的物理地址位数限制导致的。虽然8086拥有20位的地址线,但它可以表示的最大逻辑地址只有16位(即1MB的总空间)。为了实现更大的线性寻址,系统将物理地址进行了逻辑分段。

分段原因

8086的设计限制使其内部可以表示的物理地址不超过16位(即16KB)。为了满足更大的寻址需求(1MB),系统采取了逻辑分段的方式。每个段的大小最大为64KB,最小为16B。通过分段,8086可以同时支持更大的地址空间。

存储单元的物理地址

在分段管理中,物理地址被分解为两个部分:

  • 段基址:段基址是段的起始地址,由系统分配给段。而且段基址必须是16的倍数(即高16位),低4位总为0000。段基址值的高16位即可用于表示段的起始位置。
  • 段内偏移地址:段内偏移地址用于指示段内的具体位置。它是相对于段基地址的偏移量,使用16位的二进制数表示。
  • 逻辑地址的组成

    逻辑地址由两个部分组成:

    • 段基址(0000H ~ FFFFH):由段寄存器决定。
    • 段内偏移地址(0000H ~ FFFFH):由指令直接提供。

    这两部分结合在一起,形成完整的物理地址。具体来说,逻辑地址通过以下公式计算物理地址:物理地址 = 段基址 + 段内偏移地址

    这种分段机制为8086提供了灵活的地址分配方式,支持到1M字节的总存储空间。

    转载地址:http://uumqz.baihongyu.com/

    你可能感兴趣的文章
    NuGet(微软.NET开发平台的软件包管理工具)在VisualStudio中的安装的使用
    查看>>
    nuget.org 无法加载源 https://api.nuget.org/v3/index.json 的服务索引
    查看>>
    Nuget~管理自己的包包
    查看>>
    NuGet学习笔记001---了解使用NuGet给net快速获取引用
    查看>>
    nullnullHuge Pages
    查看>>
    NullPointerException Cannot invoke setSkipOutputConversion(boolean) because functionToInvoke is null
    查看>>
    null可以转换成任意非基本类型(int/short/long/float/boolean/byte/double/char以外)
    查看>>
    Number Sequence(kmp算法)
    查看>>
    Numix Core 开源项目教程
    查看>>
    numpy
    查看>>
    Numpy 入门
    查看>>
    NumPy 库详细介绍-ChatGPT4o作答
    查看>>
    NumPy 或 Pandas:将数组类型保持为整数,同时具有 NaN 值
    查看>>
    numpy 或 scipy 有哪些可能的计算可以返回 NaN?
    查看>>
    numpy 数组 dtype 在 Windows 10 64 位机器中默认为 int32
    查看>>
    numpy 数组与矩阵的乘法理解
    查看>>
    NumPy 数组拼接方法-ChatGPT4o作答
    查看>>
    numpy 用法
    查看>>
    Numpy 科学计算库详解
    查看>>
    Numpy.fft.fft和numpy.fft.fftfreq有什么不同
    查看>>