- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 1、数据的存储格式 计算机中信息的单位 二进制位Bit:存储一位二进制数:0或1 字节Byte:8个二进制位,D7~D0 字Word:16位,2个字节,D15~D0 双字DWord:32位,4个字节,D31~D0 最低有效位LSB:数据的最低位,D0位 最高有效位MSB:数据的最高位,对应字节、字、双字分别指D7、D15、D31位 存储单元及其存储内容: 每个存储单元都有一个编号;被称为存储器地址 每个存储单元存放一个字节的内容 多字节数据在存储器中占连续的多个存储单元: 存放时,低字节存入低地址,高字节存入高地址; 表达时,用它的低地址表示多字节数据占据的地址空间。 D7 D0 字节 D15 D0 字 D31 D0 双字 D7 D0 00006H 78H 00005H 56H 00004H 12H 00003H 34H 00002H 00001H 00000H 低地址 0002H单元存放有一个数据34H,表达为 [0002H]=34H 0002H“字”单元的内容为: [0002H] = 1234H 0002H号“双字”单元的内容为: [0002H] = 多字节数据存放方式: 80x86处理器采用“低对低、高对高”的存储形式,被称为“小端方式Little Endian”。 相对应还存在“大端方式Big Endian”。 数据的地址对齐: 同一个存储器地址可以是字节单元地址、字单元地址、双字单元地址等 字单元安排在偶地址(xxx0B)、双字单元安排在模4地址(xx00B),被称为“地址对齐(Align)” 例:字2301的地址为0000H,为规则字; 字8967的地址为0003H,为非规则字。 1.从偶地址存储体或从奇地址存储体读写一个字节。 2.读写一个字:规则字、非规则字 对于不对齐地址的数据,处理器访问时需额外的访问存储器时间 2、 存储器的分段管理 8088CPU有20条地址线 最大可寻址空间为220=1MB 物理地址范围从00000H~FFFFFH 8088CPU存储系统中,对应每个物理存储单元都有一个唯一的20位编号,就是物理地址,从00000H ~ FFFFFH 2、 存储器的分段管理 8088CPU将1MB空间分成许多逻辑段(Segment) 每个段最大限制为64KB 段地址的低4位为0000B 这样,一个存储单元除具有一个唯一的物理地址外,还具有多个逻辑地址 分段后在用户编程时,采用逻辑地址,形式为 段地址 : 段内偏移地址 段地址说明逻辑段在主存中的起始位置 偏移地址说明主存单元距离段起始位置的偏移量 物理地址和逻辑地址的转换: 一个物理地址可以有多个逻辑地址 逻辑地址 1460:100、 1380:F00 物理地址 14700H 14700H 14600H + 100H 14700H 13800H + F00H 14700H 段地址左移4位 加上偏移地址 得到物理地址 段寄存器值 偏移量 + 物理地址 16位 4位 16位 20位 物理地址为:段地址(左移四位)+段内偏移量 8086存储器20位物理地址的形成 段寄存器 8088有4个16位段寄存器 CS(代码段)指明代码段的起始地址 SS(堆栈段)指明堆栈段的起始地址 DS(数据段)指明数据段的起始地址 ES(附加段)指明附加段的起始地址 每个段寄存器用来确定一个逻辑段的起始地址,每种逻辑段均有各自的用途 CS:IP SS:SP DS:EA ES:EA 如何分配各个逻辑段? 程序的指令序列必须安排在代码段 程序使用的堆栈一定在堆栈段 程序中的数据默认是安排在数据段,也经常安排在附加段,尤其是串操作的目的区必须是附加段 数据的存放比较灵活,实际上可以存放在任何一种逻辑段中 逻辑段的分配及寄存器对应关系示意 段超越的使用(前缀指令): 没有指明时,一般的数据访问在DS段;使用BP访问主存,则在SS段 默认的情况允许改变,需要使用段超越前缀指令;8088指令系统中有4个: CS: ;代码段超越,使用代码段的数据 SS: ;堆栈段超越,使用堆栈段的数据 DS: ;数据段超越,使用数据段的数据 ES: ;附加段超越,使用附加段的数据 段超越的示例: 没有段超越的指令实例: MOV AX,[2000H] ;AX←DS:[2000H] ;从默认的DS数据段取出数据 采用段超越前缀的指令实例: MOV AX,ES:[2000H];AX←ES:[2000H] ;从指定的ES附加段取出数据 段寄存器的使用规定:
文档评论(0)