博客
关于我
微机原理 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/

    你可能感兴趣的文章
    object detection错误Message type "object_detection.protos.SsdFeatureExtractor" has no field named "bat
    查看>>
    object detection错误之Could not create cudnn handle: CUDNN_STATUS_INTERNAL_ERROR
    查看>>
    object detection错误之no module named nets
    查看>>
    Object of type 'ndarray' is not JSON serializable
    查看>>
    Object Oriented Programming in JavaScript
    查看>>
    object references an unsaved transient instance - save the transient instance before flushing
    查看>>
    Object.assign用法
    查看>>
    Object.create
    查看>>
    Object.keys()的详解和用法
    查看>>
    objectForKey与valueForKey在NSDictionary中的差异
    查看>>
    Objective - C 小谈:消息机制的原理与使用
    查看>>
    OBJECTIVE C (XCODE) 绘图功能简介(转载)
    查看>>
    Objective-C ---JSON 解析 和 KVC
    查看>>
    Objective-C 编码规范
    查看>>
    Objective-Cfor循环实现Factorial阶乘算法 (附完整源码)
    查看>>
    Objective-C——判断对象等同性
    查看>>
    objective-c中的内存管理
    查看>>
    Objective-C之成魔之路【7-类、对象和方法】
    查看>>
    Objective-C享元模式(Flyweight)
    查看>>
    Objective-C以递归的方式实现二叉搜索树算法(附完整源码)
    查看>>