什么是内存
  1.存储单元
  用于存放数据的硬件,程序执行前先放到内存中才能被CPU处理
2.内存地址
  给内存存储单元编地址,从0开始每个地址对应一个存储单元,可以按字节编址,也可以按字长编址,一个存储单元一个字节或字长

 

内存运行的基本原理
  1.指令的工作原理
    内存有数据段和程序段,指令存放在程序段,变量存放在数据段
    程序编译成指令,会告诉CPU应该去内存的哪个地址存取数据,数据应该进行怎样的处理

  2.逻辑地址 vs 物理地址
    逻辑地址是相对地址 , 物理地址是绝对地址 ,编译后装入过程是把逻辑地址到物理地址转换

  3.从写程序到程序运行:编辑-->编译-->链接-->装入
    编译:把高级语言编译成机器语言,生成多个目标模块
    链接:把目标模块形成完整逻辑地址
    装入:形成物理地址

4.三种链接方式->形成逻辑地址
  静态链接:将各目标模块和所需库函数连接成完整的可执行文件
  装入时动态链接:边装入边链接
  运行时动态链接:边运行边链接

5.三种装入方式->形成物理地址
  绝对装入:编译时就知道程序产生的绝对地址
  静态重定位:编译后装入的时候将逻辑地址转换成物理地址,位置不可更改
  动态重定位:运行时指令运行的过程中进行逻辑地址到物理地址转换,现在都采用这种方式,需要重定位寄存器

内存空间的分配和回收
内存空间的扩展(虚拟性,把物理较小的内存扩展成较大的内存)
内存的地址转换

绝对装入:编译时就知道程序产生的绝对地址
静态重定位:编译后装入的时候将逻辑地址转换成物理地址,位置不可更改
动态重定位:运行时指令运行的过程中进行逻辑地址到物理地址转换,现在都采用这种方式,需要重定位寄存器

内存保护:进程只能访问自己的内存空间
1)采用上下限寄存器
2)采用重定位寄存器和界地址寄存器,重定位(基址寄存器)存储起始物理地址,界地址寄存器(限长寄存器)存储最大逻辑地址