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;
}