[英]Lazy copying - how to create a deep copy from shallow copy
我有一个使用延迟复制的类-调用复制构造函数时,它会创建浅表副本,而调用一个方法时,它将创建深表副本并添加更多数据。
我被困在应该从该浅表副本创建深表副本的位置。
深拷贝应如下所示:
m_count = copy.m_count;
k = copy.k;
m_record = new TRecord * [k*SIZE];
char * temp;
for(int i=0;i<m_count;i++) {
m_record[i] = new TRecord;
temp = new char[12];
strcpy(temp, copy.m_record[i]->Id);
m_record[i]->Id = temp;
temp = new char[strlen(copy.m_record[i]->Name) + 1];
strcpy(temp, copy.m_record[i]->Name);
m_record[i]->Name = temp;
temp = new char[strlen(copy.m_record[i]->Surname) + 1];
strcpy(temp, copy.m_record[i]->Surname);
m_record[i]->Surname = temp;
}
但我不知道该如何实现该方法。 我试图创建一个临时对象并用* this填充它
temp.m_count = this->m_count;...
最后
*this=temp;
但这不起作用。
为什么我不首先创建深层副本? 因为副本太多,所以更改的副本很少,因此占用了大量内存。
我该怎么办?
PS我被禁止在此任务中使用STL和字符串。
您可以将所有数据成员分隔为一个类或结构,并在副本之间共享此数据(使用引用计数)。 所有想要更改数据的方法都必须检查当前对象是否为独占数据所有者,否则将对数据进行深层复制。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.