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