互站网站源码,app注册推广平台,做网站业务员应该了解什么,一站式服务建站动态内存函数
1.1malloc和free
C语言提供了一个动态内存开辟的函数#xff1a;
void* malloc (size_t size);
这个函数向内存申请一块连续可用的空间#xff0c;并返回指向这块空间的指针。 如果开辟成功#xff0c;则返回一个指向开辟好空间的指针。如果开辟失败#…动态内存函数
1.1malloc和free
C语言提供了一个动态内存开辟的函数
void* malloc (size_t size);
这个函数向内存申请一块连续可用的空间并返回指向这块空间的指针。 如果开辟成功则返回一个指向开辟好空间的指针。如果开辟失败则返回一个NULL指针因此malloc的返回值一定要做检查。返回值的类型是 void* 所以malloc函数并不知道开辟空间的类型具体在使用的时候使用者自己来决定。如果参数 size 为0malloc的行为是标准是未定义的取决于编译器 使用malloc开辟空间实例
#define _CRT_SECURE_NO_WARNINGS 1
#includestdio.h
#includestdlib.h
int main()
{char* p (char*)malloc(10);if (p NULL){perror(malloc);return 1;}int a 97;for (int i 0; i 10; i){*p a;printf(%c ,*p);a;}free(p);p NULL;return 0;
} 在上面的代码中我们看到了陌生的free函数这个函数是做什么用的呢
可以看到标题写的malloc和free函数是搭配在一起来使用的我们既然向内存借用申请了空间那么在结束的是时候一定要free释放掉我们借来的“东西”。
C语言提供了另外一个函数free专门是用来做动态内存的释放和回收的
void free (void* ptr);
free函数用来释放动态开辟的内存。 如果参数 ptr 指向的空间不是动态开辟的那free函数的行为是未定义的。如果参数 ptr 是NULL指针则函数什么事都不做。 1.2calloc
C语言还提供了一个函数叫 calloc calloc 函数也用来动态内存分配
void* calloc (size_t num, size_t size); calloc函数的功能是为 num 个大小为 size 的元素开辟一块空间并且把空间的每个字节初始化为0。calloc函数与函数 malloc 的区别只在于 calloc 会在返回地址之前把申请的空间的每个字节初始化为全0 calloc函数实例
#define _CRT_SECURE_NO_WARNINGS 1
#includestdio.h
#includestdlib.hint main()
{int* p (int*)calloc(10, sizeof(int));//开辟10个整型大小的空间----40字节if (p NULL){perror(calloc);return 1;}free(p);p NULL;return 0;
} 开辟出来的40个字节的内存空间在最初就被初始化为0了
1.3realloc
realloc函数的出现让动态内存管理更加灵活。
有时会我们发现过去申请的空间太小了有时候我们又会觉得申请的空间过大了那为了更合理使用内存我们会对内存的大小做灵活的调整。那 realloc 函数就可以做到对动态开辟内存大小进行二次调整。void* realloc (void* ptr, size_t size); ptr 是要调整的内存地址size 是调整之后新大小返回值为调整之后的内存起始位置。这个函数在调整原内存空间大小的基础上还会将原来内存中的数据移动到新的空间。 realloc在调整内存空间的是存在两种情况
情况1原有空间之后有足够大的空间情况2原有空间之后没有足够大的空间 当是情况1 的时候要扩展内存就直接原有内存之后直接追加空间原来空间的数据不发生变化。当是情况 2 的时候原有空间之后没有足够多的空间时扩展的方法是在堆空间上另找一个合适大小的连续空间来使用。这样函数返回的是一个新的内存地址
#include stdio.h
int main()
{int* ptr (int*)malloc(100);if (ptr ! NULL){//业务处理}else{exit(EXIT_FAILURE);}//扩展容量//代码1ptr (int*)realloc(ptr,INT_MAX);//这样可以吗(如果申请失败会如何)//更改申请的内存空间大小如果更改的时候后续空间不足会发生原申请的内存空间指针丢失的后果//业务处理free(ptr);return 0;
} 正确使用方式应该是额外使用一个变量来接收 realloc 开辟的内存空间的地址如果开辟成功则返回地址再赋给ptr这样就保证了原来开辟空间的地址不会丢失避免造成内存泄漏 正确方式
#include stdio.h
int main()
{
int *ptr (int*)malloc(100);
if(ptr ! NULL)
{
//业务处理
}
else
{
exit(EXIT_FAILURE);
}
//扩展容量//正确恰当的方式避免出现内存泄漏问题
int*p NULL;
p realloc(ptr, 1000);
if(p ! NULL)
{
ptr p;
}
//业务处理
free(ptr);
return 0;
} 感谢支持