C动态内存开辟函数总结

malloc和free

void* malloc (size_t size);

malloc 函数向内存申请一块连续的空间,并且返回指向这块空间的地址。注意,malloc只负责动态开辟一段连续空间,并不负责这块空间的初始化。

  • 如果开辟成功,返回一个指向开辟好空间的地址。
  • 如果开辟失败,返回一个NULL指针,注意:malloc的返回值一定要走检查。
  • malloc函数并不知道要开辟多大的空间,具体大小的要自己决定。
  • 如果参数size为0,malloc的行为是不确定的,取决于编译器。
void free (void* ptr);

free函数是专门用来做动态开辟内存的释放和回收。

  • 如果参数ptr 指向的空间不是动态开辟的,则free函数的行为是不确定的。
  • 如果参数ptr 是NULL,则函数什么都不做。
int *arr[10] = { 0 };
    int *p =(int*) malloc(sizeof(int)*10);  //为指针p开40字节的空间
    if (p != NULL)
    {
        for (int i = 0; i < 10; i++)
        {
            *(p+i) = 2;
        }
    }

    free(p);
    p = NULL;

这里写图片描述

这里写图片描述

注意:
动态内存开辟的空间一定要free。如果不free的话会出现内存泄漏问题。

calloc

void* calloc (size_t num, size_t size);
  • calloc函数是为num个大小为size的元素开辟一块空间,并且把空间的每个字节初始化为0。这是与malloc函数的一大区别。

    这里写图片描述

realloc

有时我们会发现过去申请的空间太小了,或者太大了,为了合理的内存,需在原来的内存上调整大小,而realloc函数就能够解决这一问题。

void* realloc (void* ptr, size_t size);
  • ptr是要调整的内存地址
  • size是调整之后的新大小
  • 返回值为调整之后的内存起始地址
  • 这个函数调整原内存空间大小的基础上,还会将原来内存中的数据挪到新的空间。

用realloc函数共有2种情况:

  1. 原来空间之后有足够大的空间,这时候要扩展的内存就直接在原有内存之后直接追加,原来空间的数据不发生变化。

    这里写图片描述

  2. 原有内存之后没有足够大的空间,这时候在堆空间上另外找一块合适大小的连续空间,将原来内存的数据也拷到新内存中,这样函数返回一个新的内存地址。
    这里写图片描述

猜你喜欢

转载自blog.csdn.net/ddcodingya/article/details/80452397