malloc的实现
//malloc
#include <stdio.h>
#include<stdlib.h>
int main(){
//malloc()中表示的是申请内存空间的大小
int *p = (int*)malloc(10 * sizeof(int));
for (int i = 0; i < 10;++i )
{
p[i] = i;
}
for (int i = 0; i < 10;++i )
{
printf("%d\n", p[i]);
}
//内存释放,不释放的话跟随整个程序
//如果一直申请但不释放,会引起内存泄漏
//后续再申请就申请不到了
free(p);
system("pause");
return 0;
}
calloc的实现
#include <stdio.h>
#include<stdlib.h>
//calloc练习
int main(){
int *p = (int*)calloc (10,sizeof(int));
for (int i = 0; i < 10; ++i)
{
p[i] = i;
}
for (int i = 0; i < 10; ++i)
{
printf("%d\n", p[i]);
}
free(p);
system("pause");
return 0;
}
realloc实现
函数原型
void *realloc(void *ptr, size_t size);
其中参数ptr是旧内存区域的地址,size是需要的新的内存区域的大小。
分配时,首先判断ptr指向的区域是否有足够的空间,如果有,则增大(或减少)该内存区域,然后将ptr返回;如果ptr指向的区域没有足够的空间,则分配一段新的内存区域,并且将原ptr的数据拷贝到新的内存区域,释放ptr指向的内存区域(内部完成,不需要外部使用free),返回新的内存区域的地址。
如果 ptr = NULL,那么相当于调用 malloc(size);如果 size = 0,那么相当于调用 free(ptr)。
如果 ptr 不为 NULL,那么他肯定是由之前的内存分配函数返回的,例如 malloc()、calloc()或realloc()。
#include <stdlib.h>
#include<stdio.h>
int main()
{
char* p = (char *)malloc(100);
if (p)
printf("内存分配在: %p\n", p);
else
printf("没有足够内存!/n");
char *lcf = (char *)realloc(p, 256);
if (lcf)
printf("内存重新分配在: %p\n", lcf);
else
printf("没有足够内存!/n");
free(lcf);
system("pause");
return 0;
}