我有一个名为Path
extends的类std::vector<Square *>
,其中Square
也是我创建的一个类。Path
它将作为实体穿越 2D 环境的指南。我需要获得最长的路径和最短的路径,因此我希望找到Squares
一个Path
. 为此,我觉得重载 , 将是有益的std::vector<Square *>::push_back(const value_type &__x)
,尽管我不确定它的语法是什么。我目前正在尝试这个:
class Path : public std::vector<Square *>
{ //... functional stuff, not relevant.
int length;
public:
push_back(const value_type &__x)
{ Square *last_square = this->at(this->size() - 1);
// how do I call super class push_back?
// however that works, I push back &__x square here.
Square *most_recent = (Square *)&__x;
int delta_x = compare_distance(last_square, most_recent);
length += delta_x;
};
int path_length() { return length; };
};
当然,我想我可以只为超类编写一个调用 push_back 的方法,但我觉得重写该函数更简洁,而且学习如何正确重写 stl 函数对我来说是一个好习惯。
谢谢!