Linux内核--内存管理(三)物理内存分页机制

一、引言
二、物理内存模型
------>2.1、平坦内存模型(Flat Memory Model)
------>2.2、对称多处理 SMP(Symmetric MultiProcessing)
------>2.3、非均衡访存模型 NUMA(Non-Uniform Memory Access)
三、节点、区域和页
------>3.1、节点
------>3.2、区域
------>3.3、页
------------>3.3.1、整页使用方式
------------>3.3.2、小块内存使用方式–slab
------>3.4、Linux分区页框分配器
四、用户态页的分配
------>4.1、伙伴系统
------>4.2、slub allocator
------>4.3、kmem_cache
五、内核页表
六、页面交换
  • 26
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Linux内核中,有多种常用的内存管理算法,用于有效地管理系统内存资源。以下是一些常见的内存管理算法: 1. 分页(Paging):分页是一种将物理内存划分成固定大小的页面,将进程的虚拟地址空间映射到物理内存的算法。通过分页,操作系统可以将进程的虚拟地址空间分割成多个页面,并将这些页面映射到物理内存上。 2. 页表(Page Table):页表是一种数据结构,用于记录虚拟地址和物理地址之间的映射关系。当进程访问虚拟地址时,操作系统会通过页表查找对应的物理地址。 3. 页面置换(Page Replacement):页面置换算法用于在物理内存不足时选择合适的页面进行置换。常见的页面置换算法包括最佳置换算法(OPT)、先进先出算法(FIFO)、最近最久未使用算法(LRU)等。 4. 内存回收(Memory Reclamation):内存回收算法用于释放不再使用的内存页面,以便重新分配给其他进程使用。常见的内存回收算法包括垃圾回收和页面回收。 5. 内存碎片整理(Memory Fragmentation):内存碎片整理算法用于解决内存碎片问题,将多个小内存块整理成连续的大内存块,以提高内存利用率。 6. 交换(Swapping):交换是一种将进程的部分或全部数据从内存移到磁盘上的操作。当系统内存不足时,操作系统可以将一部分进程数据交换到磁盘上,以释放物理内存。 这些算法在Linux内核中被广泛应用于内存管理,以提供高效的内存分配和管理机制。具体选择哪种算法取决于系统的需求和性能要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

文艺小少年

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值