Linux 内存的申请和释放

一、介绍

  1. 内核态函数定义
    与C语言编程时常用的malloc()、free()函数类似,LINUX内核态分别用kmalloc()、kfree()实现与核心内存接口的功能要求。
  2. 用户态函数定义
    与C语言编程时常用的malloc()、free()函数类似,LINUX用户态分别用vmalloc()、vfree()实现功能要求。

二、Kmalloc内存分配函数

void * kmalloc(size_t size ,int flags)

  1. kmalloc可分配的空闲内存来自free_area[]数组;
  2. 当空闲块数低于min_free_page时,只得换出其他页面;
  3. 换页过程中,该调用kmalloc函数的进程暂时挂起,CPU调度其他就绪进程;
  4. 如果下一个进程,也调用kmalloc函数,这要求该函数必须是可重入函数;

三、Kfree内存释放函数

void Kfree(const void * objp)

  1. 必须是通过kmalloc分配的内存;
  2. objp是地址;
  3. 如果当前待释放的对象是在slab完全块,则将该slab链接移植非完全块;如果是非完全块,则判断是否为空闲块,然后判断移植空闲链表;

四、Vmalloc内存分配函数

1.Kmalloc()由存储空间在进程的虚拟空间是连续的,但是对应的屋里内存仍需要经缺页中断后,由缺页服务程序分配。
2.分配的物理页帧也不是连续的,这个特征与访问用户态内存相似,所以不妨把Vmalloc和Vfree称为用户内存的申请和释放界面。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux内存慢速申请策略是指在系统内存紧张的情况下,为进程分配内存的一种策略。当系统内存不足时,操作系统需要采取措施来调度和管理可用内存,以实现公平的内存分配。 Linux内核使用了基于页面的内存管理机制。当一个进程请求分配内存时,操作系统会尝试从空闲内存池中分配一页或多页的内存给该进程。当没有足够连续的空闲内存页可供分配时,操作系统将触发一种称为"慢速申请策略"的机制,即系统将尝试通过动页面调度来释放足够的可用内存Linux内核会根据内存需求情况进行页面换入和换出操作,从而在进程之间动调整可用内存。具体来说,当系统内存紧张时,内核会通过将一部分内存页从磁盘交换区(swap space)中换入到内存中来释放可用内存。同时,对于不活跃的进程,内核还可以将其页面换出到磁盘交换区,从而释放更多的可用内存。 此外,Linux内核还使用了页回写、页面按需分配和页面归还等技术来调整内存的使用情况。页回写指的是将修改过的页面写回到磁盘上,以释放可用内存。页面按需分配是指当进程需要更多内存时,内核只会分配一部分页面,随着进程的内存使用量增加,内核会根据需求逐渐分配更多的页面。页面归还则是指当不需要的页面被内核回收时,内核会将这些页面归还给内存池,以供其他进程使用。 综上所述,Linux内存慢速申请策略通过动页面调度、页面换入换出、页回写、页面按需分配和页面归还等技术手段来实现对系统内存的合理管理和分配,从而保证系统在内存紧张的情况下仍能维持正常的运行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值