一、malloc
1.函数原型
void *malloc(size_t size);
2.函数功能
malloc()在内存的动态存储区中分配一块长度为size字节的连续区域。参数size为需要的内存空间的长度,返回该区域的地址。
3.区别
malloc不能初始化所分配的内存空间,需要用memset,而函数calloc能做到。如果这部分内存曾经被分配过,则其中可能遗留各种各样的数据。
二、calloc
1.函数原型
void *calloc(size_t nmemb, size_t size);
2.函数功能
calloc()与malloc()相似,参数size为申请地址的单位元素长度,nmemb为参数个数。
3.区别
calloc会将所分配的空间中的每一位都初始化为零。
三、realloc
1.函数原型
void *realloc(void *ptr, size_t size);
2.函数功能
realloc()是给一个已经分配了地址的指针重新分配空间,参数ptr为原有的空间地址,newsize是重新申请的地址空间。3.区别
realloc可以对给定的指针所指向的空间进行扩大或缩小,原有的内存中的内容将保持不变。realloc并不保持调整后的内存空间和原来的内存空间保持同一内存地址,返回的指针很可能指向新的地址。
四、实现原理
malloc、calloc函数的实质是将一块可用的内存连接为一个链表。调用malloc函数时,它沿连接表寻找一个大到足以满足用户请求所需要的内存块,然后将该内存块一分为二(一块与用户申请的大小一样,另一块是剩下的字节组成的内存块)。接下来,将分配给用户的那块内存地址传给用户,调用free函数时,它将用户释放的内存块连接到空链上,最后空闲链表会被切成很多的小内存片段。
realloc是从堆空间上分配内存,当扩大一块内存空间时,realloc试图直接从现存的数据后面的哪些字节中获得附加的字节,如果能够满足需求,自然不会出现意外,如果后面的字节不够,那么就使用堆上第一个足够满足要求的自由空间块,现存的数据然后就被拷贝到新的位置上,而老块则放回堆空间,这可能会导致数据被移动。
1.函数原型
void *malloc(size_t size);
2.函数功能
malloc()在内存的动态存储区中分配一块长度为size字节的连续区域。参数size为需要的内存空间的长度,返回该区域的地址。
3.区别
malloc不能初始化所分配的内存空间,需要用memset,而函数calloc能做到。如果这部分内存曾经被分配过,则其中可能遗留各种各样的数据。
二、calloc
1.函数原型
void *calloc(size_t nmemb, size_t size);
2.函数功能
calloc()与malloc()相似,参数size为申请地址的单位元素长度,nmemb为参数个数。
3.区别
calloc会将所分配的空间中的每一位都初始化为零。
三、realloc
1.函数原型
void *realloc(void *ptr, size_t size);
2.函数功能
realloc()是给一个已经分配了地址的指针重新分配空间,参数ptr为原有的空间地址,newsize是重新申请的地址空间。3.区别
realloc可以对给定的指针所指向的空间进行扩大或缩小,原有的内存中的内容将保持不变。realloc并不保持调整后的内存空间和原来的内存空间保持同一内存地址,返回的指针很可能指向新的地址。
四、实现原理
malloc、calloc函数的实质是将一块可用的内存连接为一个链表。调用malloc函数时,它沿连接表寻找一个大到足以满足用户请求所需要的内存块,然后将该内存块一分为二(一块与用户申请的大小一样,另一块是剩下的字节组成的内存块)。接下来,将分配给用户的那块内存地址传给用户,调用free函数时,它将用户释放的内存块连接到空链上,最后空闲链表会被切成很多的小内存片段。
realloc是从堆空间上分配内存,当扩大一块内存空间时,realloc试图直接从现存的数据后面的哪些字节中获得附加的字节,如果能够满足需求,自然不会出现意外,如果后面的字节不够,那么就使用堆上第一个足够满足要求的自由空间块,现存的数据然后就被拷贝到新的位置上,而老块则放回堆空间,这可能会导致数据被移动。