【C基础】堆内存创建/释放和内存清理函数/内存泄漏

本文介绍了C语言中的堆内存管理,包括为何使用堆内存、malloc的内存分配机制、如何正确申请和释放内存以避免内存泄漏,以及如何定义和操作堆内存上的二维数组。还提及了字符串处理的基本概念和相关练习。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本期涉及到了较多的指针,没有彻底领悟的同学请翻阅之前的博文~

一闪一闪亮晶晶,满天都是小星星***

什么是堆内存:

是进程的一个内存段(text、data、bss、heap、stack)之一,由程序员手动管理,
特点就是足够大,缺点就是使用麻烦。

为什么使用堆内存:

1、随着程序的复杂数量变多。
2、堆内存的申请释放受控制。

如何使用堆内存:

注意:C语言中没控制堆内存的语句,只能使用C标准库提供的函数。
#include <stdlib.h>

void *malloc(size_t size);
功能:从堆内存中申请size个字节的内存,申请内存中存储是什么内容不确定。
返回值:成功返回申请到的内存的首地址,失败返回NULL。


void free(void *ptr);
功能:释放一块堆内存,可以释放NULL,但不能重复释放和非法地址。
注意:释放仅仅是使用权,里面的数据不会被特意清理。

申请,释放和置空堆内存:

#include <stdio.h>
#include <stdlib.h>

int main(int argc,const char* argv[])
{
   
	// 从堆上分配一块内存,首个字节的地址存放在指针变量p中
	int* p = malloc(sizeof(int)*10);

	for(int i=0; i<10; i++)
	{
   
		p[i] = i;	
		printf("%d\n",p[i]);
	}

	// 解引用  使用堆内存
	*p = 1000;

	printf("%d\n",*p);

	// 释放堆内存
	free(p);
	// 重复释放会导致堆内存崩溃
	// free(p);
	// free只是释放使用权,数据不会被特意清理
	for(int i=0; i<10; i++)
	{
   
		printf("%d\n",p[i]);
	}

	// 堆内存释放后指针要及时置空
	p = NULL;
	
}

void *calloc(size_t nmemb, size_t size);
功能:从堆内存中申请nmemb块size个字节的内存,申请的内存块会被初始化为0。
注意:申请的依然是一块连续的内存。


void *realloc(void *ptr, size_t size);
功能:改变已经有内存块的大小,在原有的基础上调大或调小。
返回值:是调整后的内存块的首地址,一定要重新接收返回值,可能不是在原内块上调整的。
    如果无法在原内存块上进行调整:
        1、申请一块新的符合要的内存块
        2、把原内存块上的内容拷贝过去
        3、把原内存释放掉返回新内存块的首地址
注:realloc函数有个争议性话题,对于大型工程可能存在内存泄漏,本人目前未能亲自验证,但不可不防。
#include <stdio.h>
#include <stdlib.h>

int main(int argc,const char* argv[])
{
   
	int* p = malloc(40);
	for(int i=0; i<10; i++)
	{
   
		p[i] = i;
		printf("%d ",p[i]);
	}
	malloc(20);

	int* p1 = realloc(p,80);
	printf("%p %p\n",p,p1);

	for(int i=0; i<10; i++)<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值