你如何在 C++ 中将 class 转换为它的子class?

How do you cast a class to its subclass in c++?

我来自 Java 背景,其中扩展(继承自)其他 class 的 class 经常作为超级 class 传递。我希望在 C++ 中做类似的事情,但我以前从未使用过 C++ 继承。我目前有以下内容:

class Obstacle{
    double get_position(){return position;}
};

class Wall : public Obstacle {
    double get_normal(){return normal;}
};

一般来说,障碍物可以是任何形状,但墙壁是矩形的,因此具有易于设计的法线,这对于大多数障碍物来说并不合适。然而,另一个 class 有一个包含所有障碍的聚合 std::vector<Obstacle*>。当遍历这些 Obstacles 并进行计算时,我需要对不同类型的 Obstacles 进行单独计算(superclass 中也有一个 get_type() 函数)。当我有一个 Wall 时,我希望能够调用 get_normal(),但是如果我尝试 static_cast<Wall>(current_obstacle)->get_normal(),我会得到编译错误:no matching function call to Wall(Obstacle*&)。如果我使用 ((Wall)current_obstacle)->get_normal(),它也会给出同样的错误。似乎我应该制作一个 Wall 构造函数,它接受一个 Obstacle 并创建一个新的 Wall 对象,但这些对我来说似乎没有意义。

在 Java 中,我可以使用 ((Wall)current_obstacle).get_normal() 将任何 class 转换为其子 class。这在 C++ 中也可能吗?我必须创建一个构造函数吗?提前致谢。抱歉我的理解不够。

static_cast<Wall>(current_obstacle)->get_normal()

尝试

static_cast<Wall*>(current_obstacle)->get_normal()

首先,如果 current_obstacleObstacle* 类型,那么您应该将其转换为 Wall*。目前您正在尝试将指针转换为新对象,但这不起作用。

其次,考虑使用dynamic_cast代替static_cast。这将检查指向的对象是否真的是 Wall 类型,如果不是,return 将是一个空指针。 static_cast 不检查,如果你的 Obstacle* 没有真正指向 Wall 但你投它并调用 Wall 成员函数。 (如您所知,在 Java 中转换总是为您执行此检查。)