c语言内存申请空间服务器内存


目录前言

1.关于动态内存的函数1.1malloc和free函数1.2calloc函数1.3realloc函数

2.常见的动态内存错误2.1对NULL指针解引用2.2对动态内存开辟的空间

关于动态内存管理,可能有学习过的小伙伴,也有没有听说过的。没有听说过的小伙伴会觉得很奇怪啊,为什么要动态开辟内存,内存怎么还能是动态的。给不知道的小伙伴解释一下。咱们平时在内存开辟空间也就是在栈区(局部变量,函数参数等等),静态区(全局变量,static修饰的局部变量等等)开辟空间。只能是用多少开辟多少,是非常局限的。有时候我们需要的空间大小在程序运行的时候才能知道,那数组的编译时开辟空间的方式就不能满足了,所以就试试动态内存存储。而动态内存开辟的空间都是在内存中的堆空间的。

malloc这个函数向内存申请一块连续可用的空间,并返回指向这块空间的指针,如果开辟成功,则返回一个指向开辟好空间的指针;如果开辟失败,则返回一个NULL指针,因此malloc的返回值一定要做检查。

free函数专门是用来做动态内存的释放和回收的。如果参数ptr指向的空间不是动态开辟的,那free函数的行为是未定义的;如果参数ptr是NULL指针,则函数什么事都不做。

该函数设计的巧妙的一点就是返回值为void*,因为函数创造者并不知道使用者是想以什么样的类型指针来接收动态开辟的空间,所以使用者在使用时只需要强行转换成自己想要的类型就可以:

在使用完动态开辟的空间后记得要用free函数向操作系统释放开辟的空间,并且将指针赋为空指针:

calloc可与malloc函数相对照来学习,calloc函数的功能是为num个大小为size的元素开辟一块空间,并且把空间的每个字节初始化为
0。与malloc有两点不同:

参数不同,calloc需要指明开辟空间的数据类型和该类型数据的个数,而malloc是全部字节数;

realloc函数用来调整开辟空间的大小,有时可能开辟的空间小了,有时候可能开辟的大了,都可以通过realloc函数来修改,并且会将原来内存中的数据移动到新的空间。

原有空间后有足够大的空间,这种情况下扩展内存就直接原有内存之后直接追加空间,原来空间的数据不发生变化,返回值为原来位置的指针;



2.原有空间后没有足够大的空间,这时便在堆空间找到大小合适的连续空间使用,并将原有空间的数据转移到新的空间返回值为新空间的地址。

这就是忽略了返回值可能是空指针的可能,如果开辟失败会返回空指针。所以最好的做法就是判断一下指针是否为空,然后再进行下一步。

通过查阅MSDN可以发现:Attemptingtofreeaninvalidpointer(apointertoamemoryblockthatwasnotallocatedbycalloc,malloc,orrealloc)mayaffectsubsequentallocationrequestsandcauseerrors.就是说如果用free释放非calloc,malloc,realloc函数动态开辟的空间可能会导致后续的分配请求并且导致错误。

如果使用完动态内存又不释放则会导致这块内存无法在后续被利用,导致内存泄漏。动态开辟的空间一定要释放,并且正确释放。



3.用数组保存多个元素时,很难预知实际运行时存储的元素个数,往往会导致预定义的元素个数不足或过多

动态数据结构可以在运行时灵活地添加、删除或重排数据项。动态内存管理可以在运行时分配更多的内存空间或释放掉不再需要的空间,因而可以优化存储空间的使用。

所以———由于无法预知在运行时数组元素的使用情况,在程序中预定义的数组大小,如果过小,会导致程序运行失败;如果过大,则会浪费内存空间。

到此这篇关于C语言中动态内存的文章就介绍到这了,更多相关C语言动态内存内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!