指针3

158 阅读2分钟

「这是我参与2022首次更文挑战的第11天,活动详情查看:2022首次更文挑战」。

动态内存分配

传统数组的缺点:
    1、数组长度必须事先制定,且只能是常整数,不能是变量
        例子:int a[3];//OK
        int len = 3;int a[len];//error
    2、传统形式定义的数组,该数组的内存程序员无法手动释放
        数组一旦定义,系统为该数组分配的存储空间就会一直存在,
          除非数组所在函数运行结束
        在一个函数运行期间,系统为该函数中数组所分配的空间会一直存在,知道该函数运行完毕时,数组的空间才会释放。
    3、数组的长度一旦定义,其长度就不能再更改
    数组的长度不能再函数运行的过程中动态的扩充或缩小
    4A函数定义的数组,在A函数运行期间可以被其他函数使用,但A函数运行完毕之后,A函数中的数组将无法再被其他函数使用
    

举个例子

# include<stdio.h>
void g(int * pArr,int len)
{
    pArr[2] = 88;
}
void f(void)
{
    int a[5] = {1,2,3,4,5};
    
    g(a,5);
    printf("%d\n",a[2]);
}
int main(void)
{
    f();
    
    return 0;
}

如果释放了f();则数组a[]也不能使用

为什么需要动态分配内存
    动态数组很好的解决了传统数组的这4个缺陷
    传统数组也叫静态数组
动态内存分配举例_动态数组的构造

image.png

    12行分配了8个字节,p变量占4个字节,p所指向的内存也占4个字节
    p本身所占的内存是静态分配的,p所指向的内存是动态分配的
    
#include<stdio.h>
#include<malloc.h>
void f(int * q)
{
    //*p=200;//error
    //q = 200;
    //**q = 200;//error
    *q = 200;
    free(q);//把q所指向的内存释放
}
int mian(void)
{
    int * p = (int *)malloc(sizeof(int));
    *p = 10;
    
    printf("%d\n",*p);//10
    f(p);
    printf("%d\n",*p);//200
    
    return 0;
}

image.png

静态内存和动态内存的比较
        静态内存是由系统自动分配,由系统自动释放
        静态内存是在栈分配的。
        
        动态内存是由程序员手动分配,手动释放
        动态内存是在堆分配的。
还有一些不太重要的内容后面会一一补充。