汇编(二) 内存地址空间、寄存器、物理地址以及物理地址的计算

简介: 汇编、内存地址空间、寄存器、物理地址、物理地址的计算、汇编指令

内存地址空间:

    一个CPU的地址线宽度为10,那么可以寻址1024个内存单位,这1024

    个可寻到的内存单元构成这个CPU的内存地址空间

    最终运行程序的是CPU,用汇编编程的时候。必须要从CPU角度考虑问题

    对于CPU来讲,系统中的所有存储器中的存储单元都是处于一个统一的逻辑存储器中,他的容量

    受CPU寻址能力的限制,这个逻辑存储器就是我们所说的地址空间

7f5514c4fe1b7121efa7c49605eb3030c76af715


主板:

    每一台pc机中都有一个主板,主板上有核心器件和一些主要器件

    这些器件通过三类总线相连接

236d1980e2eaaf47e0781ea74a26e9d056f5633f


接口卡:

    计算机系统中 所有可用程序控制其工作的设备,必须受到CPU的控制

存储器芯片:

    随机存储器(RAM)和只读存储器(ROM)

    从功能分类和链接上分类:

        随机存储器RAM

        装有BIOS的ROM

        接口卡上的RAM


16个基本寄存器:

  EAX  ABX  ECX  EDX 为通用寄存器

  EBP:栈区基地址寄存器;

  ESP:栈顶寄存器;

  ESI :源寄存器;

  EDI:目的寄存器;

  CS:代码段寄存器;

  DS:数据段寄存器;

  ES:扩展数据段寄存器;

  SS:栈段寄存器;

  FS:扩展数据段计算器;

  GS:扩展数据段计算器;

  EFLAGS:标志寄存器;


通用存储器:

    一个16位的寄存器可以存储一个16位的数据,最大值为2的16次方-1

    寄存器AX分为 AL、AH

    0位~7位构成了AL低位寄存器, 8位~15位构成了AH高位寄存器

    AH和AL寄存器可以独立使用

字在寄存器中的存储:

    一个字可以存在一个16位寄存器中,这个字的高位和低位字节自然就存在这个寄存器的高8位和低8位

    一个字为2b、2个字节、16位


023af75115de55d45f298cde4dc3c41221a7e86b


数制:

    由于一个内存单元可以存放8位数据,CPU中的寄存器又可以存放n个8位数据

    也就是说 计算机中的数据大多数是由1~n个8位数据构成的


    用十六进制来表示数据可以直观的看出这个数据是由哪些8位数据构成的,

    二进制每4位对应一个十六进制, 每3位对应一个8进制


汇编指令(不区分大小写):

    mov ax, 18   将8送入AX   AX = 18

    mov ah, 78   将78送入AH  AH = 78

    add ax, 8    将寄存器AX中的数值加上8         AX = AX+8

    mov ax, bx   将寄存器BX中的数据送入寄存器AX   AX = BX

    add ax, bx   将AX,BX中的内容相加 结果给AX   AX = AX+BX


检测点(以下数字均为十六进制):

    mov ax, 62627     AX = 2627  # 溢出取后4位

    mov ah, 31        AX = 5727

    mov al, 23        AX = 574a  # al低寄存器 高位忽略 计算低位 溢出同样后两位

    add ax, ax        AX = ae94

    mov bx, 826c      BX = 826c

    mov cx, ax        CX = ae94

    mov ax, bx        AX = 826c

    add ax, bx        AX = 3100

    mov al, bh        AX = 3182

    mov ah, bl        AX = 6c82

    add ah, ah        AX = ce82  # ah高寄存器 低位忽略 计算高位 溢出同样取后两位


物理地址:

    CPU访问内存单元时要给出内存单元的地址,所有的内存单元构成的存储空间

    是一个一维的线性空间。我们将这个一维的地址称为物理地址


16位结构的CPU:

    16位结构描述了一个CPU具有哪几方面特征:

        1.运算器一次最多可以处理16位的数据

        2.寄存器的最大宽度为16位

        3.寄存器和运算器之间的通路是16位的


8086CPU读写内存时,发生了这么一些事:

    1.CPU中的相关部件提供两个16位的地址,一个称为段地址,一个为偏移地址

    2.段地址和偏移地址通过内部总线送入一个称为地址加法器的部件

    3.地址加法器将两个16位地址合并成一个20位的地址


881a5bd9ed087d55404c8105ddb2cbe5762b2200


地址加法器的工作原理:

    地址加法器合成物理地址的方法:

        物理地址=段地址*16+偏移地址

        注:此处为20位物理地址

    段地址*16  二进制向左移4位、16进制左移1位

    1.一个数据的二进制形式左移1位,相当于*2,16进制*16、10进制*10、x进制*x

    2.一个数据的二进制形式左移n为,相当于该数据*2的n次方

    

7fc2114fb66100bda8a5aa019ee2318d133984b9

相关文章
|
3月前
|
存储 开发框架 .NET
"揭秘.NET内存奥秘:从CIL深处窥探值类型与引用类型的生死较量,一场关于速度与空间的激情大戏!"
【8月更文挑战第16天】在.NET框架中,通过CIL(公共中间语言)可以深入了解值类型与引用类型的内存分配机制。值类型如`int`和`double`直接在方法调用堆栈上分配,访问迅速,生命周期随栈帧销毁而结束。引用类型如`string`在托管堆上分配,堆栈上仅存储引用,CLR负责垃圾回收,确保高效且自动化的内存管理。
56 6
|
21天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
194 2
|
1月前
|
C++
析构造函数就是为了释放内存,就是在局部指针消失前释放内存,拷贝构造函数就是以构造函数为模块,在堆里面新开一块,同一个变量在堆里面的地址
本文讨论了C++中构造函数和析构函数的作用,特别是它们在管理动态内存分配和释放中的重要性,以及如何正确地实现拷贝构造函数以避免内存泄漏。
37 2
|
1月前
|
存储 安全 NoSQL
driftingblues9 - 溢出ASLR(内存地址随机化机制)
driftingblues9 - 溢出ASLR(内存地址随机化机制)
37 1
|
2月前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
130 5
|
3月前
|
算法 安全 UED
探索操作系统的内核空间:虚拟内存管理
【7月更文挑战第50天】 在现代操作系统中,虚拟内存管理是核心功能之一,它允许操作系统高效地使用物理内存,并为应用程序提供独立的地址空间。本文将深入探讨操作系统虚拟内存管理的机制,包括分页、分段以及内存交换等关键技术,并分析它们如何共同作用以实现内存的有效管理和保护。通过理解这些原理,读者可以更好地把握操作系统的内部工作原理及其对应用程序性能的影响。
|
2月前
|
Linux Shell 虚拟化
使用LiME收集主机物理内存的内容时发生宕机
使用LiME收集主机物理内存的内容时发生宕机
|
2月前
crash —— 获取物理内存布局信息
crash —— 获取物理内存布局信息
|
6月前
|
存储 Unix 编译器
汇编语言----X86汇编指令
汇编语言----X86汇编指令
224 2