2

我们有一个名为 Student 的父类。我们有一个子类:StudentCS。

学生.h:

#include <iostream.h>
#include<string.h>
#include<vector.h>
#include "Course.h"
class Course;

class Student {
public:
    Student();
    Student(int id, std::string dep, std::string image,int elective);
    virtual ~Student();
    virtual void Study(Course &c) const;  // this is the function we have a problem with
    void setFailed(bool f);
[...]

};

学生.cpp:

#include "Student.h"

[...]

void  Student::Study(Course &c) const {

}

我们有 StudentCS.h:

#include "Student.h"
class StudentCS : public Student {
public:
StudentCS();
virtual ~StudentCS();
StudentCS (int id, std::string dep, std::string image,int elective);
void Study(Course &c) const;
void Print();
};

和 StudentCS.cpp:

void StudentCS:: Study (Course &c) const{
    //25% to not handle the pressure!
    int r = rand()%  100 + 1;
cout << r << endl;
if (r<25) {
    cout << student_id << " quits course " << c.getName() << endl;
}

 }

我们主要创建学生:

Student *s;
vector <Student> uniStudent;
[...]
    if(dep == "CS")
        s = new  StudentCS(student_id,dep,img,elective_cs);
    else
        s = new StudentPG(student_id,dep,img,elective_pg);

    uniStudent.push_back(*s);

然后我们打电话去学习,但我们让父母学习,而不是孩子!请帮忙!

代码可以编译,但是在 uniStudent.Study() 上运行和调用时,它使用父级而不是子级

4

1 回答 1

7

编辑:编辑后问题很清楚。

问题是您将基础具体对象存储在 STL 容器中。这会产生一个称为对象切片的问题。

当您将学生添加到 avector<Student>时,由于向量的分配器是基于类构建的,因此Student派生类的所有附加信息都将被丢弃。一旦将元素插入向量中,它们就会成为基本类型。

要解决您的问题,您应该使用 avector<Student*>并在其中直接存储对学生的引用。所以分配器只与指针相关,不会对你的对象进行切片。

vector<Student*> uniStudent;
...
uniStudent.push_back(s);
uniStudent[0]->study();

请注意,您可能希望使用智能指针以更健壮的方式管理所有内容。

于 2012-11-21T18:43:13.287 回答