Это совершенно безопасно.
Следующий пример кода:
#include <iostream>
#include <boost/shared_ptr.hpp>
int main(int, char**)
{
boost::shared_ptr<int> a(new int(5));
boost::shared_ptr<const int> b = a;
std::cout << "a: " << a.use_count() << std::endl;
std::cout << "b: " << b.use_count() << std::endl;
return EXIT_SUCCESS;
}
Компилируется и работает нормально, и это совершенно правильно. Выводит:
a: 2
b: 2
Два shared_ptr
используют один и тот же счетчик ссылок.
Также:
#include <iostream>
#include <boost/shared_ptr.hpp>
class A {};
class B : public A {};
int main(int, char**)
{
boost::shared_ptr<A> a(new B());
boost::shared_ptr<B> b = boost::static_pointer_cast<B>(a);
std::cout << "a: " << a.use_count() << std::endl;
std::cout << "b: " << b.use_count() << std::endl;
return EXIT_SUCCESS;
}
Веди себя так же. Однако вы должны никогда строить свой shared_ptr
, используя такую конструкцию:
boost::shared_ptr<A> a(new B());
boost::shared_ptr<B> b(static_cast<B*>(a.get()));
a.get()
дает необработанный указатель и теряет всю информацию о подсчете ссылок. В результате вы получите два разных (не связанных) shared_ptr
, которые используют один и тот же указатель, но разные счетчики ссылок.