重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
动态内存分配即分配内存大小在运行时才确定,一般在堆中分配。C语言动态内存分配相关的函数。
创新互联专注于中大型企业的成都做网站、网站制作、成都外贸网站建设和网站改版、网站营销服务,追求商业策划与数据分析、创意艺术与技术开发的融合,累计客户千余家,服务满意度达97%。帮助广大客户顺利对接上互联网浪潮,准确优选出符合自己需要的互联网运用,我们将一直专注高端网站设计和互联网程序开发,在前进的路上,与客户一起成长!
malloc
#include stdlib.h
void * malloc (size_t size);
malloc的使用比较直接,一个成功的malloc调用返回分配的size大小的内存的指针。失败时返回NULL并将错误代码置为ENOMEM。
教材中经常出现的用法是将malloc返回的void指针进行强制内存转换然后赋给内存指针,其实是不必要的,在赋值时C语言是可以将void类型指针自动转换成对应的指针的。
calloc
#include stdlib.h
void * calloc (size_t nr, size_t size);
calloc可以分配nr个size大小的内存空间,一般用于一组struct结构体的分配。
那么calloc和malloc有什么区别呢?抛开nr参数不谈(malloc也可以将参数设置为nr*size达到一样的效果),最关键的区别是malloc分配的内存是不保证初始化的,而calloc会将分配的内存都初始化为0.
realloc
#include stdlib.h
void * realloc (void *ptr, size_t size);
realloc函数将ptr指向的内存空间重新分配大小为size并返回新的内存首地址。具体的实现,函数首先会尝试直接在已经分配的内存后进行padding,如果空间足够那么还是返回原来的地址,如果不够,则会寻找新的空间并malloc size个字节,之后再将原先的内容“搬家”到新的内存地址,所以函数的返回值可能和原指针相同,也可能不同。
另外,size参数如果是0,则该函数和free效果相同。如果ptr是NULL,函数的效果和malloc相同~
free
#include stdlib.h
void free (void *ptr);
释放前三个函数申请的内存空间。关于free最经典的问题就是内存泄露(memory leak)。所以,使用前三个分配函数分配的内存一定要记得free掉。
你这段代码的问题是arr是a的地址,你不断减arr很快就会减出数据区(应该是到了只读区吧)。所以不可能执行10000次。关于内存分配的问题我不太记得了,不过C一般也不用考虑内存分配的问题。如果你感兴趣的话对代码反汇编然后再研究下吧。推荐你看下《linux+C编程》这本书,里面对于内存分配有很详细的说明。
c语言中malloc是动态内存分配函数,malloc()函数其实就在内存中找一片指定大小的空间,然后将这个空间的首地址范围给一个指针变量,这里的指针变量可以是一个单独的指针,也可以是一个数组的首地址,这要看malloc()函
内存重置函数:从c地址开始重置size2个字节,将每个字节的内容重置为a
memset(c,a,size2)
C语言中malloc是动态内存分配函数。
函数原型:void *malloc(unsigned int num_bytes)。
参数:num_bytes 是无符号整型,用于表示分配的字节数。
注意:当内存不再使用时,应使用free()函数将内存块释放。函数返回的指针一定要适当对齐,使其可以用于任何数据对象。关于该函数的原型,在以前malloc返回的是char型指针,新的ANSIC标准规定,该函数返回为void型指针,因此必要时要进行类型转换。
实现malloc的方法:
首先我们要确定所采用的数据结构。一个简单可行方案是将堆内存空间以块的形式组织起来,每个块由meta区和数据区组成,meta区记录数据块的元信息(数据区大小、空闲标志位、指针等等)。
数据区是真实分配的内存区域,并且数据区的第一个字节地址即为malloc返回的地址 。