要使用war_red里warrior的成员函数的代码该怎么写
时间: 2024-02-12 13:07:47 浏览: 25
如果要使用 `war_red` 向量中 `warrior` 类型的成员函数,需要使用指针或引用来访问向量中的对象。以下是一个使用指针的示例:
```cpp
// 遍历 war_red 向量,调用每个 warrior 对象的 attack() 成员函数
for (auto it = war_red.begin(); it != war_red.end(); ++it) {
(*it)->attack();
}
```
在这个示例中,使用迭代器访问向量中的对象,并使用指针运算符 `->` 访问 `warrior` 类型的成员函数 `attack()`。
如果要使用引用的话,可以像这样:
```cpp
// 遍历 war_red 向量,调用每个 warrior 对象的 show() 成员函数
for (auto& w : war_red) {
w.show();
}
```
在这个示例中,使用了 `auto&` 引用类型,将向量中的每个 `warrior` 对象传递给了循环变量 `w`。然后,可以像访问普通对象一样,使用点号 `.` 访问 `warrior` 类型的成员函数 `show()`。
无论是使用指针还是引用,都需要注意访问向量中的对象时,是否需要使用动态绑定来调用派生类的成员函数。
相关问题
vector<warrior> war_red;warrior* p;p = new dragon(1, hp[n], num, atk[n]); p->show(); war_red.push_back(*p);为什么vector内部是空的,要如何修改这段代码
这段代码中创建了一个 dragon 对象,并将其加入到 war_red 向量中,但是 war_red.push_back() 接收的是对象的副本,而不是指针或引用。因此,这段代码中创建的 dragon 对象在添加到 war_red 向量中后,它的生命周期已经结束,而向量中只剩下了它的一个副本。
要解决这个问题,可以将 war_red 向量中的元素类型改为指针类型,如下所示:
```cpp
vector<warrior*> war_red;
warrior* p = new dragon(1, hp[n], num, atk[n]);
p->show();
war_red.push_back(p);
```
这样就可以将创建的 dragon 对象的指针加入到 war_red 向量中,而不是将对象的副本加入到向量中。注意,在修改后的代码中,需要手动释放创建的 dragon 对象的内存,以防止内存泄漏。可以在程序结束前,循环遍历 war_red 向量,释放其中的每个对象的内存。
void warrior::fight(warrior& a, int i) a.yell(i);a调用的是派生类的成员函数yell,代码该如何修改
可以使用作用域解析运算符 `::` 来指定调用基类的成员函数。代码如下:
```
void warrior::fight(warrior& a, int i) {
warrior::yell(i);
}
```
这样就可以在 `fight` 函数中调用基类 `warrior` 的成员函数 `yell` 了。