内存管理

内存管理

内存的发展历程

DOS时代,同一时间只能有一个进程在运行(也有一些特殊算法可以支持多线程)
Windows9x --多个进程装入内存:两个问题:内存撑爆,互相打扰,为了解决这两个问题,诞生了现在的内存管理系统:虚拟地址 分页装入,软硬件结合寻址。
1、分页:解决内存不够用问题,
内存中分成固定大小的页框(4K),把程序(硬盘上)分成4K大小的块,用到哪一块,加载哪一块。加载的过程中如果内存已满,会把最不常用的一块放到swap交换分区,把最新的一块加载进来。这个就是著名的LRU算法。
LRU算法,LeetCode146题,头条要求手撕,阿里去年也要求手撕。
LRU(Least Recently Used)、LFU 算法:所有涉及到缓存的都可以用同样的思想。
哈希表(保证查找操作O(1)),链表保证排序操作和新增操作O(1)
双向链表:保证调整指针指向(不用找前一个结点,直接在当前结点操作)时间复杂度O(1)

2、虚拟内存:解决相互打扰的问题:虚拟地址空间
为了保证互不影响,让进程工作在虚拟空间,程序中用到的空间地址不再是直接的物理地址,而是虚拟地址,这样A进程永远不可能访问到B进程的空间。
虚拟空间多大呢?寻址空间-64位系统2^64,比物理空间大很多。
站在虚拟的角度,进程是独享整个系统+CPU

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值