C语言 动态内存学习小结
前言
浅薄的学习了动态内存的使用,在这记录学习脚步,若有错误请麻烦各位指正
一、动态内存函数原型(<stdlib.h>)
1.void* malloc(size_t size) 2.void free(voidptr) 3.void calloc(size_t num,szie_t size) 4.void* realloc(void* ptr,size_t size)
二、函数的简单使用
1.堆区空间的开辟与释放(malloc、calloc与free,开辟空间要在使用结束后使用free函数释放)
首先是malloc的使用,malloc函数的函数参数为所要开辟的字节数size,返回开辟地址指针,类型为void,所以在开辟后需要根据所开辟类型进行强制类型转换,free函数与malloc函数配套,其输入参数为动态空间的地址指针。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
int* p = (int*)malloc(40);
if (p == NULL)
printf("%s",strerror(errno));
else
for (int i = 0; i < 10; i++)
{
p[i] = 1;
printf("%d\n", p[i]);
}
free(p);
p = NULL;
}
calloc函数的函数参数为开辟字节大小num和所开辟空间的类型的字节大小size,与malloc函数一样,返回类型为void*。与malloc函数不同的是,calloc函数将开辟空间的每个字节初始化为0。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
int* p = (int*)calloc(40,sizeof(int));
if (p == NULL)
printf("%s",strerror(errno));
else
for (int i = 0; i < 10; i++)
printf("%d\n", p[i]);
free(p);
p = NULL;
}
2.空间大小调整(realloc) realloc函数的第一个函数参数为所要调整的空间地址,第二个函数参数为所要增加的空间字节数,返回类型为void*,这里返回的指针有两种可能,第一种:如果在堆区中,原先空间后有足够空间供你增加,那么返回的指针指向原来开辟空间;第二种:原先空间后面无法满足你要增加的空间,那么realloc会重新开辟空间,大小即为原先空间大小加上你要增加的空间大小size,这时候返回的指针就不是原来开辟的空间了,而是新的空间,但是也达到了调整原先空间的目的。
``
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
int* p = (int*)calloc(40,sizeof(int));
if (p == NULL)
printf("%s",strerror(errno));
else
for (int i = 0; i < 10; i++)
printf("%d\n", p[i]);
int*p1=(int*)realloc(p, 80);
for (int j = 0; j < 80; j++)
{
printf("%d\n", p1[j]);
}
free(p);
p = NULL;
}
上面代码就属于第二种情况,调整前后的地址是不同的。
三、动态内存函数常见的错误使用
1.动态内存开辟后未进行检验是否开辟成功 如果使用malloc或calloc开辟空间不成功,则会返回空指针NULL,以此来检验空间是否开辟成功。若不检验,万一空间没开辟成功然后又直接使用,就会非法访问。 2.在开辟动态空间后一定要用free函数进行回收 否则会导致内存不断被浪费而导致内存泄漏 3.free函数只能对开辟的动态空间进行释放 4.free的输入参数必须是开辟动态空间的起始地址 5.free释放空间后,要将指向原先释放空间的指针赋值为NULL,不然也会出现非法访问的问题
|