C动态内存分配(被调函数内部指针内存分配)

本文详细介绍了C++中的内存分配函数malloc和free,以及它们与new和delete的区别。通过示例展示了如何在栈区使用返回指针和二级指针的方式来管理动态内存。

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

void *malloc(size_t size);
void free(void *);
malloc在内存的动态存储区中分配一块长度为size字节的连续存储空间返回该区域的首地址
 

与c++中的内存分配new和delete作用相同(但c++的可适用范围更广)

当在栈区,被调函数之外需要使用被调函数内部的指针对应的地址空间是时候,有两种解决方案.

一、通过返回动态内存的指针

二、通过二级指针来保存

代码演示如下:

第一种方法

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<stdlib.h>
#include<string.h>

//通过返回动态内存的指针
int* demo(int count)
{
	int* ap = NULL;

	ap = (int*)malloc(sizeof(int) * count);//分配给指针ap的内存大小为4*count
	//等价ap=new int[count];

	//指针赋值
	for (int i = 0; i < count; i++)
	{
		ap[i] = 100 + i;
	}

	//输出
	for (int i = 0; i < count; i++)
	{
		printf("*(ap+%d)=%d\n", i, *(ap + i));
	}
	return ap;
}

int main()
{
	//两种方式调用函数内部的内存
	int* pointer = NULL;
	int count = 10;

	//第一种
	pointer = demo(count);

	//第二种

	//输出验证在main函数中调用了被调函数内部指针的内存
	for (int i = 0; i < count; i++)
	{
		printf("*(pointrt+%d)=%d\n", i, *(pointer + i));
	}

	//释放内存
	free(pointer);//相当于delete
	return 0;


}

 

第二种:

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<stdlib.h>
#include<string.h>

//通过返回动态内存的指针
//int* demo(int count)
//{
//	int* ap = NULL;
//
//	ap = (int*)malloc(sizeof(int) * count);//分配给指针ap的内存大小为4*count
//	//等价ap=new int[count];
//
//	//指针赋值
//	for (int i = 0; i < count; i++)
//	{
//		ap[i] = 100 + i;
//	}
//
//	//输出
//	for (int i = 0; i < count; i++)
//	{
//		printf("*(ap+%d)=%d\n", i, *(ap + i));
//	}
//	return ap;
//}

//通过二级指针
void demo2(int count, int **pointer_p)
{
	int* ap=NULL;

	*pointer_p = (int *)malloc(sizeof(int) * count);

	ap = *pointer_p;//相当于pointer的地址

	//赋值
	for (int i = 0; i < count; i++)
	{
		ap[i] = 100 + i;
	}

	//输出
	for (int i = 0; i < count; i++)
	{
		printf("*(ap+%d)=%d\n", i, *(ap + i));
	}

}

int main()
{
	//两种方式调用函数内部的内存
	int* pointer = NULL;
	int count = 10;

	//第一种
	//pointer = demo(count);

	//第二种
	demo2(count, &pointer);

	//输出验证在main函数中调用了被调函数内部指针的内存
	for (int i = 0; i < count; i++)
	{
		printf("*(pointrt+%d)=%d\n", i, *(pointer + i));
	}

	//释放内存
	free(pointer);//相当于delete
	return 0;


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值