将派生类的实例存储在C++中
storing the instances of the derived class in C++
我看到很多人使用new
来创建派生类的实例,然后在某个容器中保留一个指向基类的指针。对于每个派生类使用一个容器,这有什么好处吗?我的意思是下面的
class A
{
public:
vector<Base*> bases;
set<Derived1> der1;
set<Derived2> der2;
//other stuff
};
编辑:删除了问题的第二部分,并添加为注释
如果执行以下
vector<base*> bases;
然后可以在对象上使用多态性。想象一下,你有一个名为Vehicule的基类。它有一个从a点到B点的move()方法。
class Vehicule
{
public:
virtual void move(){}
}
然后你有两个派生类:汽车和潜艇
class Car : public Vehicule
{
public:
void move()
{
checktires();
drive();
}
}
和你的子类
class Submarine : public Vehicule
{
public:
void move()
{
submersion();
propulsion();
}
}
因为move方法是一个虚拟方法,所以您将执行多态性。这是一种机制,允许您调用相同的函数,但根据对象的动态类型具有不同的行为。
我会尽力解释那句话。现在您有了Vehicule、Car和Submarine类,您将创建一个Vehicle指针数组(或像向量一样的stl容器)。
std::vector<Vehicule*> objects;
objects.push_back(new Car());
objects.push_back(new Submarine());
objects[0]->move();
objects[1]->move();
第一个move调用将调用Car方法中定义的move方法。第二个将调用潜艇中定义的动作。因为你可能有一个向量Vehicule*,但当你调用函数时,因为它是虚拟的,你调用的是它的适当版本。只调用一个函数,你就会有不同的行为。你可以添加尽可能多的Vehicule派生类,你只需要调整move方法。
你应该在stackoverflow中搜索多态性,有比我刚才写的更详细、更准确的答案。
对不起,我不是以英语为母语的人
相关文章:
- 将字符串存储在c++中的稳定内存中
- std::原子加载和存储都需要吗
- C++:将控制台输出存储在宏中更好吗
- 使用QProcess执行命令,并将结果存储在QStringList中
- 访问存储在向量C++中的结构的多态成员
- 如何从存储在std::映射中的std::集中删除元素
- 存储模板类型以强制转换回派生<T>
- 类型总是使用其大小存储在内存中吗
- 当字符串存储在变量中时,如何将字符串转换为wchar_t
- 使用无符号字符数组有效存储内存
- 如何在cpp.中使用协议缓冲区存储大缓冲区/数组(char/int)
- 使用 pqxx 将 std::vector 存储在 postgresql 中,并从数据库中检索它
- 带结构的二维矢量:如何存储元素
- 添加存储在向量中的大整数的函数出现问题
- 从文件中读取多个字节,并将它们存储在C++中进行比较
- 在std::vector上存储带有模板的类实例
- 谷歌测试中的期望值存储在哪里
- 为什么C中的通用链表中存储的数据已损坏
- 在c++中获取两个大int,并将它们存储在数组中
- 在reactor中存储eventHandlers的最佳方式是什么