c语言学习6(堆内存管理,内存泄漏,内存碎片,内存清理)

#include <stdlib.h>

   void *malloc(size_t size);
    功能:从堆内存中申请size个字节的内存,申请内存中存储是什么内容不确定。
    返回值:成功返回申请到的内存的首地址,失败返回NULL
注意:void* 在c++编译中不能自动转换成其他类型的指针,如果想让代码在c++中兼容需要强制类型转换。
int* p=(int*)malloc(4);
   
    void free(void *ptr);
    功能:释放一块堆内存,可以释放NULL,但不能重复释放和非法地址。
    注意:释放仅仅是使用权,里面的数据不会被特意清理

    释放完内存后将指针手动置空。

    void *calloc(size_t nmemb, size_t size);
    功能:从堆内存中申请nmeb块size个字节的内存,申请的内存块会被初始化位0。
    注意:申请的依然是一块连续的内存。
                 
    void *realloc(void *ptr, size_t size);
    功能:改变已经有内存块的大小。在原有的基础上调大或调小。
    返回值:是调整后的内存块的首地址,一定要重新接受返回值,可能不是在圆内存块上调整的。
        如果无法在原内存块上进行调整:
            1、申请一块新的符合要求的内存块
            2、把原内存块上的内容拷贝过去
            3、把原内存释放掉返回新内存的首地址

malloc的内存管理机制:
当首次向malloc申请内存时,malloc会向操作系统申请内存,操作系统会直接分配33页(1页=4096字节)内存交给malloc管理。

	但这不意味着可以越界访问,因为malloc把使用分配给”其他人“,这样会产生脏数据。
	每个内存块之间会有些空隙(4~12字节),这些空隙一些是为了内存对齐,其中4个字节记录着malloc维护信息,这些维护信息决定下次分配内存的位置,也可以计算出每个内存块的大小,当这些信息被破坏时就会影响malloc和free函数的调用

使用堆内存要注意的问题:
内存泄漏:
内存无法再使用也无法再释放。
而再次使用时只能重新申请,然后重复过程,日积月累导致系统中可用的内存越来越少。
注意:程序以但结束属于它的资源都会被操作系统回收。
服务器端的程序无法随意停止,有些停止会导致数据丢失。

注意:谁申请,谁释放。谁知道该释放谁释放。
如何判断/定位内存泄漏:
    1、查看内存的系统使用情况
    2、使用代码分析工具检查malloc的调用情况
    3、包装malloc、free,记录申请、释放的信息到日志中。

内存碎片:
    已经释放的但无法再继续使用的内存,是由于申请和释放的时间不协调导致的,无法避免只能尽量减少。

如何减少内存碎片:
    1、尽量使用栈内存。
    2、不要频繁的申请释放内存。
    3、尽量申请大块内存,自己管理。

内存清理函数:
#include <strings.h>

void bzero(void *s,size_t n)
功能:把一块内存清理为0
s:内存块的首地址
n:内存块的字节数

#include <string.h>
void *memset(void *s,int c,size_t n);
功能:把内存块按字节设置为c
s:内存块的首地址
c:相设置的ASCII码值
n:内存块的字节数
返回值:设置成功后的内存首地址
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值