c中动态开辟内存的几个函数


1、malloc和free
#include
  函数原型:(void*) malloc(size_t n);
  int *=(int*)malloc(sizeof(int)*10);
 
  这个函数使用上较为简单,有兴趣的同学可以类比依稀它还有另外的两个版本,回顾一下我们c语言的知识,我们在这里就不回顾了。对于这个函数我们的理解上要注意以下几点:
   
    1)我们malloc里只接收要开辟的内存大小,也就是说它接受的是实参是多少个
字节。
    2)我们malloc成功返回的是的是直向这块内存的一个void*类型的指针,它只
负责开辟多大的内存,并不关心你用它放什么数据,所以给用户返回的是void*类型
的指针,提供给用户使用上的自由。
    3)我们可以将得到的void*指针强转成我们这块所需要存放的数据类型。
    4)通常,我们都是将函数的返回值强转然后用一个相同类型的指针接受我们
动态开辟的空间的起始地址,并通过它去使用这个指针。
    5)我们需要注意的是动态开辟的空间都需要释放,不然它在程序的运行期间,会一直占用堆上的资源,产生的问题也就是我们所说的内存泄漏。当然程序要想在内存上运行,它得产生相应的进程,所以当我们程序运行结束的时候,也就是进程结束的时候,肯定会释放掉进程 所占用的的资源,堆上的资源肯定有时候会释放的,只是说作为一名合格的程序员,我们能及时解决并且能自己解决的问题,不要全都丢给操作系统,它要干的事情太多了,我们能做的尽量自己做。
   
   6)使用结束后,我们可以自己利用free函数将它释放掉。

2、calloc
for(int i=0;i
{
     p[i]=0;
}

它比malloc多一个初始化的功能,它的第一个参数指定初始化为什么值,第二个参数是申请多少字节的内存空间。

3、realloc
第一个参数为原地址,realloc的作用申请一个新的空间,然后把旧的地址东西写入新的空间,当然新的空间肯定是比原来的大,如果你新申请的空间比原来小,它就不会干什么事了,也不会把原来的释放,分一个更小的,因为它认为既然分出去了,虽然你现在不需要,可能还会需要。然后我们得道新的空间之后,把旧的空间释放,并且把指向旧空间的指针指向新的空间,这样用户感觉仿佛还是在用原来的空间,而且容量增大了。

猜你喜欢

转载自blog.csdn.net/betty2017/article/details/78696790