最近学习了在堆上的内存分配,下面是一些总结和笔记
//一,通过返回值分配内存
int *getspace()
{
//malloc函数的返回值是分配区域的起始地址
//函数原型为void *malloc(unsigned int size);
//其作用是在内存的动态存储区中分配一个长度为size的连续空间
int *p = (int *)malloc(sizeof(int) * 5);//在堆上动态分配内存
if (NULL == p)
{
return NULL;
}
//往分配的内存里面写值
for (int i = 0; i < 5; ++i)//++i 比i++ 的效率高
{
//只要是连续的空间都能使用下标的方式访问
p[i] = 100 + i;
}
return p;
}
void test()
{
int *ret = getspace();
for (int i = 0; i < 5; ++i)
{
cout << ret[i] << endl;
}
free(ret);//释放堆上动态分配的内存
ret = NULL;//避免出现野指针
}
//二,通过参数传递指针分配内存
//1.错误写法
//这种写法程式运行会死掉,原因是allocateSpace(ret)函数执行后,参数p指向malloc函数分配的内存0x88(举例),allocateSpace执行完后p被释放0x88内存泄漏,ret指向为空
void allocateSpace(char *p)
{
p= (char *)malloc(100);
memset(p, 0, 100);
strcpy(p,"hello world");
}
void test1()
{
char *ret = NULL;
allocateSpace(ret);
cout << "ret=" << ret;
}
//2,正确的写法
//将&ret传入allocateSpace
void allocateSpace(char **p)
{
char *temp = (char *)malloc(100);
//memset() 函数可新申请的内存进行初始化工作
//将指针变量 p 所指向的前 100 字节的内存单元用一个“整数” 0 替换
memset(temp, 0, 100);
strcpy(temp,"hello world");
*p = temp;//*p=ret,所以实际ret指向malloc分配的内存空间
}
void test12()
{
char *ret = NULL;
allocateSpace(&ret);
cout << "ret=" << ret;//结果ret=hello world
}