我按照上一篇文章中的说明重新编写了代码。
我的头文件
#include <iostream>
#include <string>
#include <vector>
#include <cstdio>
#include <typeinfo>
#include "Tour.h"
#include "GuidedTour.h"
using namespace std;
class TourManager {
private:
vector<Tour *> tours;
void setupTour();
string getUserInput();
string displayMainMenu();
void displayTourDetails();
void callDisplayOnEach();
void addBookingsToTour();
public:
TourManager();
void go();
};
然后我有一个函数用tour和guidedTour对象填充“list”向量。
void TourManager::setupTour() {
tours.push_back(new Tour("FP001", "Fun Park 3 Day Pass", 110.00));
tours.push_back(new GuidedTour("SK003", "Learn to Ski Adventure Tour", 240.00, "28/07
}
void TourManager::callDisplayOnEach() {
for (vector<Tour *>::iterator it = tours.begin() ; it != tours.end(); ++it)
{
if(typeid(*it) == typeid(GuidedTour))
{
cout << "Guided Tour" << "\n";
}
else
{
cout << "NOT Guided Tour : " << typeid(*it).name() << "\n";
}
}
}
但是我似乎总是回到Tour对象。 EG:它总是打印NOT Guided Tour。
如何归档多态行为?
你能建议吗? (我是C ++的新手) 我需要使用C ++ 98非常感谢
答案 0 :(得分:5)
这不是多态的工作原理。
如何实现您的目标
dynamic_cast<T>
使用RTTI检查多态类型是否实际上是T
类型:
GuidedTour * ptr = dynamic_cast<GuidedTour *>(*it);
if(ptr != NULL)
{
std::cout << "This is a guided tour" << '\n';
}
然而,RTTI需要付出代价;这些是在运行时执行的检查,会降低您的性能,并且可能根本不支持RTTI。
你通常应该做什么
避免需要知道多态对象的确切类型。提供一个运行良好的界面,并依赖于调用虚拟方法来完成工作。
class Tour
{
public:
virtual ~Tour() {}
virtual void info() const
{
std::cout << "This is not a guided tour" << '\n';
}
};
class GuidedTour : public Tour
{
public:
void info() const
{
std::cout << "This is a guided tour" << '\n';
}
};
Tour * tour = new GuidedTour();
tour->info();
delete tour; // here you need the virtual destructor
虽然我们处于最佳状态;请避免原始指针。即使你被C ++ 98绑定,也有非常好的智能指针;例如,Boost提供的shared_ptr
和weak_ptr
非常类似于C ++ 11中的那些。