问题描述
class A{public: void test() { std::cout << 'test' << std::endl; }};class B : public A{public: void test2() { std::cout << 'test2' << std::endl; }};std::unique_ptr<A> Get(){ std::unique_ptr<A> b(new B); return b;}int main(){ auto o = Get(); // 如何转换为 std::unique_ptr<B> ? system('pause'); return 0;}
问题解答
回答1:直接转(downcasting/dynamic_cast)是会出错的。
你应该先把unique_ptr b 里面动态类型的指针取出来:
B* ptr = dynamic_cast<B*>(o.get());
然后重新定义一个新的unique_ptr,然后把原指针释放,新指针重置:
std::unique_ptr<B> anotherptr;if (ptr != nullptr) { o.release(); anotherptr.reset(ptr);}回答2:
unique_ptr<A> 与 unique_ptr<B> 之间无法直接转换,必须把原指针取出来再进行转换
int main(){ auto o = Get(); std::cout << typeid(o).name() << std::endl; auto x = reinterpret_cast<B*>(o.release()); std::unique_ptr<B> b(x); std::cout << typeid(b).name() << std::endl; system('pause'); return 0;}
stdout:
class std::unique_ptr<class A,struct std::default_delete<class A> >class std::unique_ptr<class B,struct std::default_delete<class B> >