How can you guarantee that the component library that your company just bought, available only in binary form isn't doing something like this?
void cool_stuff_with_widget(const std::shared_ptr<UI> ptr)
{
UI* evilPtr = const_cast<UI*>(ptr->get());
// now store evilPtr somewhere else and try to use it any time the library feels like it
}
No one is going through disassembly to check such behaviors.
C++ RC is a very welcoming addition to the language, but it only works if everyone plays by the rules, 100% of the time.
It's not really an issue, if the library is buggy and leaks or keeps reference to things it's not supposed to, it will be the same whether it's RC or just plain memory management.
It's just better documented and easier to spot the bugs if you're doing RC.
It not about bugs, rather C++'s lack of support to enforce that RC is not misused and programmers cannot grab RC internals and corrupt the data structures.
C++ is a language that allows any kind of memory manipulation, if you really want (or need) to do it. So your example doesn't prove anything about the adequacy of shared_ptr in particular.
My point was that if a language does RC via library types that exposure the pointer that they own, there is no safety guarantee about memory safety.
It is impossible to prove that all memory access to a given address are done via the RC wrapper object, specially in the presence of third party libraries in binary form.
Sadly due to its C compatibility, there is no way around this in C++.
This is mostly a problem in large projects with various skill levels across team members, having high attrition levels.
As I mentioned above, the goal of C++ is not to provide memory safety guarantees. What it provides is a mechanism for RC implementation. You're free to use or misuse it if you want. It will work only for those objects that you think should be managed with RC, nothing more or less.
It is hard to get right with existing code bases.
Additionally C++11 got a GC API, but requires explicit programmer control.
http://www.stroustrup.com/C++11FAQ.html#gc-abi
C++'s memory model is tainted by C's compatibility, as such it is quite limited in the GC algorithms that can be implemented.