这是一些代码:
#include <typeinfo>
#include <assert.h>
#include <vector>
class Super {};
class Sub1 : public Super {};
class Sub2 : public Super {};
int main() {
std::vector<Super*> vec;
vec.push_back(new Sub1);
vec.push_back(new Sub2);
assert(typeid(vec[0]) == typeid(vec[1]));
assert(typeid(vec[0]) != typeid(vec[1]));
}
不幸的是,第一个断言通过了,而第二个没有。我对这个结果并不感到惊讶,但是能够以这种方式辨别类型会很好。
我的(有点骇人听闻的)解决方法:
#include <typeinfo>
#include <assert.h>
#include <vector>
enum SubTypeEnum {
Sub1_T,
Sub2_T
};
class Super {
SubTypeEnum _type;
public:
Super(SubTypeEnum __type) : _type(__type) {}
SubTypeEnum type() { return _type; }
};
class Sub1 : public Super {
public:
Sub1() : Super(Sub1_T) {}
};
class Sub2 : public Super {
public:
Sub2() : Super(Sub2_T) {}
};
int main() {
std::vector<Super*> vec;
vec.push_back(new Sub1);
vec.push_back(new Sub2);
assert(vec[0]->type() != vec[1]->type());
assert(vec[0]->type() == vec[1]->type());
}
这会产生预期的结果,但看起来很混乱。有没有更好的方法来找出我正在处理的类型?