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);//相当于deletereturn 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);//相当于deletereturn 0;}