我正在阅读this page,并说
dynamic_cast只能用于指针和对象的引用。其目的是确保类型转换的结果是所请求类的有效完整对象。
但是当我这样做时,dynamic_cast没有给出有效的对象:
struct A{};
struct B:A{};
void main(){
A a;
B b;
B* bPtr = (B*) 0x0000001;
A* aPtr = dynamic_cast<A*>(bPtr);
//Now aPtr is the memory address 0x00000001
}
由于bPtr不包含有效的A对象,我希望dynamic_cast能够使这个转换失败,以便aPtr得到NULL。但这不会发生吗?哪一个是错的,编译器(g ++ 4.5.7)或上面提到的网页?或者我错过了一些关于dynamic_cast实际上应该做什么的事情?
编辑:答案摘要
答案 0 :(得分:2)
dynamic_cast<>
保证提供有效的对象,前提是它已正确使用。
使用此强制转换的第一个要求是多态基类(至少1个virtual
函数)。在您的示例中,A
和B
不是多态的,会导致编译错误。
第二个要求是dynamic_cast<>
应该用于向下转换,在你的情况下,你使用它进行向上转换(这很简单)。
假设它们是多态的,那么第三个要求就是在指针/对正确对象的引用上使用这个转换。
bPtr = (B*)0x0000001
无法保证引用B
的对象(主要是UB)。
这是正确的例子:
struct A{ virtual ~A() {} };
struct B : A {};
void main(){
A* pA = new B;
B* pB = dynamic_cast<B*>(pA);
}