malloc函数动态内存分配

nibiru 2019年06月17日 94次浏览

传统数组的缺点

  1. 数组长度必须事先制定,且只能是常整数,不能是变量

  2. 传统形式定义的数组,该数组的内存程序员无法手动释放(在一个函数运行期间,系统为该函数的数组分配内存空间,会一直存在,直到该函数运行完毕时,数组的空间才会被系统释放)

  3. 数组的长度一旦定义,其长度就不能更改,数组的长度不能再函数运行的过程中动态的扩充和缩小

  4. 数组不能夸函数使用,A函数定义的数组在A函数运行期间可以被其他函数使用,但A函数运行完毕之后,A函数的数组将无法再被其他函数使用

    为什么要动态分配内存?

    • 解决传统数组的缺点

    • 传统数组也叫静态数组

      动态内存分配举例

      int *p=(int *)malloc(int len);
      

      本语句分配了两块内存,一块内存是动态分配的,总共len个字节,另一块是静态分配的
      并且这块静态内存是p变量本身所占的内存,总共四个字节。

      • malloc只有一个int型的形参,表示要求系统分配的字节数
      • malloc函数的功能是请求系统len个字节的内存空间,如果请求分配成功,则返回第一个字节的地址,如果分配不成功,则返回NULL
      • malloc函数能且只能返回第一个字节的地址,所以我们需要把这个无任何意义的第一个字节的地址,转化为一个有实际意义的地址,因此,在malloc前面必须加(数据类型 *),表示把这个没有实际意义的第一个字节的地址,转化为相应类型的地址。
      int *p =(int *)malloc(50)
      
      • 表示将系统分配好的50个字节的第一个字节的地址转化为int*型的地址,更准确的说是把第一个字节的地址转化为四个四节的地址,这样p就指向了第一个的四个字节,p+1就指向了第2个的四个四节,p+就指向了第i+1个的四个字节。p[0]就是第一个元素,p[i]就是i+1个元素
      free(p)
      
      • 表示把p所指向的内存给释放掉,p本身的内存是静态的,不能由程序员手动释放,p本身的内存只能在p变量所在的函数运行终止时由系统自动释放

      静态内存和动态内存比较

      • 静态内存由系统自动分配,系统自动释放
      • 静态内存是在栈分配的
      • 动态内存由程序员手动分配,手动释放
      • 动态内存是在堆分配的
      • 动态内存在函数执行完毕之后仍然可以被其他函数使用