你如何在 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_obstacle
是 Obstacle*
类型,那么您应该将其转换为 Wall*
。目前您正在尝试将指针转换为新对象,但这不起作用。
其次,考虑使用dynamic_cast
代替static_cast
。这将检查指向的对象是否真的是 Wall
类型,如果不是,return 将是一个空指针。 static_cast
不检查,如果你的 Obstacle*
没有真正指向 Wall
但你投它并调用 Wall
成员函数。 (如您所知,在 Java 中转换总是为您执行此检查。)
我来自 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_obstacle
是 Obstacle*
类型,那么您应该将其转换为 Wall*
。目前您正在尝试将指针转换为新对象,但这不起作用。
其次,考虑使用dynamic_cast
代替static_cast
。这将检查指向的对象是否真的是 Wall
类型,如果不是,return 将是一个空指针。 static_cast
不检查,如果你的 Obstacle*
没有真正指向 Wall
但你投它并调用 Wall
成员函数。 (如您所知,在 Java 中转换总是为您执行此检查。)