深拷贝与浅拷贝

深拷贝与浅拷贝

在存在指针指向堆区,然后指针传值,就会有两个指针变量指向同一块堆区内存,这就是浅拷贝。此时如果这两个指针变量同时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造成不可预测的后果。


微信号

你可能感兴趣的:(深拷贝与浅拷贝)