内存的管理(1)

简介: 内存的管理

取指令——译码——执行——返存

计组课我们学过cpu真正读指令并非是从内存中读入,而是从cache读和存,再由cache进行取指或返存,因为cpu指令周期比内存周期速度快很多,cpu若要取指或返存都需要等待内存完成他的动作才可以进行下一步动作。

我们上一章看过用户进程的地址、虚地址(逻辑地址)和物理地址的地址码

我们回顾一下

用户进程

虚地址

 

内核模式代码混合使用虚拟,逻辑和物理寻址。每种设备使用多少取决于底层硬件和操作系统。

 

保护操作系统和用户进程

 

内存管理的目的

 

地址转化解决的问题

我们发现虚拟地址可能会是重复的,比如两三个进程的地址都是从0开始,但我们都知道物理地址等于基址加逻辑地址

 

一个所有进程的逻辑地址集合叫做逻辑地址空间

地址转换的时机

我们分析一下一个程序的的执行周期

源代码编译(汇编)成目标代码

目标代码需要将其他的目标代码等链接起来形成可加载的模块(可执行代码)

加载一些系统库变成二进制文件\镜像

 

那么逻辑地址是何时转化物理地址呢?

汇编语句中有一条在内存中取指令,那么我们要取址就需要访问地址,操作系统先访问虚拟地址(变址寄存器),加上基址寄存器中的基址得到物理地址,从而取得想要的数据。

但这个前提是加载程序前我们必须要知道基址

 

缺点:我们的进程空间是无法被移动的(只可以是连续的)

当然只要当我们程序运行时逻辑地址才会被替换成物理地址进行寻址

比如说我们执行call调用的时候

所以当我们运行之前就需要得到进程运行的准确的基址

 

上面我们提到的换算所需要的单元叫做MMU

 

曾经的电脑时直接访问物理内存的,现在考虑到安全性和物理内存空间太大才换成这个方式

连续的内存分配机制

这里提到的内存连续性,我们需要关注的是对进程内存的定位、回收、保护。

 

固定大小分区

内存的分区的大小是固定的,需要系统进行调度

相关文章
|
4月前
|
存储 消息中间件 缓存
读Flink源码谈设计:有效管理内存之道
在最初接触到Flink时,是来自于业界里一些头部玩家的分享——大家会用其来处理海量数据。在这种场景下,`如何避免JVM GC带来StopTheWorld带来的副作用`这样的问题一直盘绕在我心头。直到用了Flink以后,阅读了相关的源码(以1.14.0为基准),终于有了一些答案。在这篇文章里也是会分享给大家。
541 1
|
6月前
|
程序员 C语言 C++
动态内存管理函数的使用与优化技巧(内存函数、柔性数组)(下)
动态内存管理函数的使用与优化技巧(内存函数、柔性数组)(下)
24 0
|
6月前
|
程序员 编译器 C语言
动态内存管理函数的使用与优化技巧(内存函数、柔性数组)(上)
动态内存管理函数的使用与优化技巧(内存函数、柔性数组)(上)
32 0
|
11月前
win10桌面窗口管理器进程内存占用大解决方法
win10桌面窗口管理器进程内存占用大解决方法
589 0
|
20天前
|
存储 缓存 监控
Linux内存和硬盘空间管理技巧
了解Linux内存和硬盘管理技巧,提升系统性能和稳定性。使用`free`, `top`, `vmstat`监控内存,通过`sync`, `echo 1 > /proc/sys/vm/drop_caches`清理缓存。利用Swap分区释放内存。借助`df`, `du`检查硬盘空间,清理无用文件,使用`clean-old`, `gzip`, `tar`压缩归档。查找大文件用`find`和`du`,确保
33 0
|
1月前
|
存储 算法 Java
如何使用 Python 管理内存和避免内存泄漏?
如何使用 Python 管理内存和避免内存泄漏?
102 35
|
3月前
|
Dragonfly 算法 安全
RT-Thread快速入门-动态内存堆管理方法
RT-Thread快速入门-动态内存堆管理方法
30 0
|
5月前
|
存储 算法
内存的管理(2)
内存的管理
25 0
|
6月前
|
编译器 Linux C语言
使用new/delete动态管理内存【C/C++内存分布】
使用new/delete动态管理内存【C/C++内存分布】
40 0
|
9月前
|
程序员 编译器 C语言
玩转动态内存管理以及程序内存开辟——【C语言】
在之前我们学习过一些内存开辟的方法,比如用int float double等等,还有各种类型的数组。这些都可以开辟内存空间。但是它们所开辟的空间都是死的,开辟完之后就不能随意去更改了,非常的不方便。今天我们要学习一些新的开辟内存的方法——动态内存开辟
59 0