美文网首页C语言
深拷贝与浅拷贝

深拷贝与浅拷贝

作者: 风情云 | 来源:发表于2020-03-16 22:39 被阅读0次

    深拷贝与浅拷贝

    在存在指针指向堆区,然后指针传值,就会有两个指针变量指向同一块堆区内存,这就是浅拷贝。此时如果这两个指针变量同时free,就会出现错误,同一块堆区内存不允许free两次,结果会不可预测。就需要深拷贝的出现,在两个指针传值时,可以再手动开辟一块内存,将里面的数据复制新的堆区内存,新的指针指向这个新开辟的堆区内存,两个变量同时free就不会出现错误。

    浅拷贝

    //创建结构体
    typedef struct student
    {
        int age;
        char *name;
    }student;
    int main()
    {
        student s1;
        //动态开辟内存
        s1.name = (char*)malloc(sizeof(char)*20);
        strcpy(s1.name,"TOM");
        //浅拷贝
        student s2 = s1;
        free(s1.name);
        free(s2.name);
        return 0;
    }
    
    浅拷贝

    两次free同一块堆区内存时,第一次free后,该堆区内存变成自由的。可以被程序开辟动态内存。此时如果有程序开辟动态内存,地址刚好是这个地址。然后free(s2.name),就会造成不可预测的错误。

    深拷贝

    typedef struct student
    {
        int age;
        char *name;
    }student;
    int main()
    {
        student s1;
        s1.name = (char*)malloc(sizeof(char)*20);
        strcpy(s1.name,"TOM");
        student s2 = s1;
        //深拷贝
        s2.name = (char*)malloc(sizeof(char)*20);
        strcpy(s2.name,s1.name);
        free(s1.name);
        //free后,最好将地址赋值为NULL
        s1.name = NULL;
        free(s2.name);
        s2.name = NULL;
        return 0;
    }
    
    深拷贝

    深拷贝后,不存在两个指针变量指向同一块堆区内存,但是这两块堆区内存数据一样,也达到两个变量复制的结果,也不会因为free造成不可预测的后果。


    微信号

    相关文章

      网友评论

        本文标题:深拷贝与浅拷贝

        本文链接:https://www.haomeiwen.com/subject/oohaehtx.html