namespace std {
template <class T, class U>
shared_ptr<T> dynamic_pointer_cast(const shared_ptr<U>& r) noexcept; // (1) C++11
template <class T, class U>
shared_ptr<T> dynamic_pointer_cast(shared_ptr<U>&& r) noexcept; // (2) C++20
}
概要
shared_ptr
で管理するインスタンスに対して dynamic_cast
を行う。
戻り値
r
が空であった場合、この関数は空のshared_ptr<T>
を返却する。-
(1) :
return shared_ptr<T>(r, dynamic_cast<typename shared_ptr<T>::element_type*>(r.get()));
-
(2) :
備考
shared_ptr<T>(dynamic_cast<T*>(r.get()))
という方法は未定義動作を引き起こすので使用しないこと。
例外
投げない
例
#include <memory>
#include <iostream>
struct A {
virtual void call() const {
std::cout << "A::call" << std::endl;
}
virtual ~A() = default;
};
struct B : A {
void call() const override {
std::cout << "B::call()" << std::endl;
}
};
int main()
{
std::shared_ptr<B> b(new B());
std::shared_ptr<A> a = std::static_pointer_cast<A>(b);
// AからBへのダウンキャスト
if (std::shared_ptr<B> result = std::dynamic_pointer_cast<B>(a)) {
result->call();
}
else {
std::cout << "conversion error" << std::endl;
}
}
xxxxxxxxxx
#include <memory>
#include <iostream>
struct A {
virtual void call() const {
std::cout << "A::call" << std::endl;
}
virtual ~A() = default;
};
struct B : A {
void call() const override {
std::cout << "B::call()" << std::endl;
}
};
int main()
{
std::shared_ptr<B> b(new B());
std::shared_ptr<A> a = std::static_pointer_cast<A>(b);
// AからBへのダウンキャスト
if (std::shared_ptr<B> result = std::dynamic_pointer_cast<B>(a)) {
result->call();
}
else {
std::cout << "conversion error" << std::endl;
}
}
出力
B::call()
バージョン
言語
- C++11
処理系
- Clang: 3.0 ✅
- GCC: 4.3.6 ✅
- ICC: ??
- Visual C++: 2008 (TR1) ✅, 2010 ✅, 2012 ✅, 2013 ✅