Mr.*_*cky 4 c++ containers pointers dynamic-memory-allocation
有几次我偶然发现了我有一个需要复制的指针容器的场景.
假设我们有以下类层次结构:
学生(基础班)
StudentService
StudentService类有一个std::vector<Student*> students
字段和以下构造函数:
StudentService::StudentService(std::vector<Student*> students) {
// code
}
Run Code Online (Sandbox Code Playgroud)
仅使用std::vector::operator=
运算符和写入是不正确的this->students = students
,因为这只会复制指针地址,因此如果外部某人删除了这些指针所指向的对象,那么StudentService类就会受到影响.
解决方案是遍历students
参数中的每个指针并创建一个新的动态对象,如下所示:
for(int i = 0; i < students.size(); i++) {
this->students.at(i) = new Student(*students.at(i));
}
Run Code Online (Sandbox Code Playgroud)
但即使这样也不合适,因为它会创建ONLY Student对象.我们知道学生可以是新生,索菲尔,初中或高级.所以这是我的问题:这个问题的最佳解决方案是什么?
我想有一种方法是在每个Student类中放置一个私有枚举字段,并有4个if-else语句检查它是什么类型的Student,然后根据它创建一个新的动态对象:
for(int i = 0; i < students.size(); i++) {
if(students.at(i).getType() == FRESHMAN) {
this->students.at(i) = new Freshman(*students.at(i));
} else if(students.at(i).getType() == SOPHMORE) {
this->students.at(i) = new Sophmore(*students.at(i));
} else if {
// and so on...
}
}
Run Code Online (Sandbox Code Playgroud)
但这仍然看起来很麻烦,你会建议什么?
你正在寻找克隆模式.向Student添加clone()虚函数,在每个后代中重写并创建相应的副本.然后按照您正确指定的方式编写容器的深层副本.
编辑:我的工作假设是你的新生等班级来自学生.如果没有,请使用变体<>并应用副本访问者.
归档时间: |
|
查看次数: |
906 次 |
最近记录: |