With the advent of
std::unique_ptr, the blemished
std::auto_ptr can finally be put to rest. So for the last several days, I have been changing my code to use smart pointers and to eliminate all
delete from my code.
Although valgrind says my code is memory-clean, the semantic richness of smart pointers will make for cleaner and easier-to-understand code.
In most of the code, the translation is simple: use
std::unique_ptr for in place of the raw pointers held by the owning objects, throw out
delete, and carefully sprinkle
move() calls, as needed, to interface well with the rest of the code.
I am at the point where I am translating non-owning raw pointers to smart pointers now.
Since I was careful with the lifetimes of my objects (I ensure my modules only depend in one direction), valgrind tells me that I don't have any uninitialized reads, dangling pointers, or leaks. So, technically, I could just leave those non-owning raw pointers alone now.
However, one option is to change those non-owning raw pointers to
std::shared_ptr because I know they are acyclic. Or, would it be better to leave them as raw pointers?
I need some advice from veteran users of smart pointers as to what rules of thumb you use to decide whether to keep non-owning raw pointers as-is, or to translate them into
std::shared_ptr, keeping in mind that I constantly unit-test and valgrind my code.
EDIT: I might be misunderstanding the use of
std::shared_ptr - can they be used in conjunction with
std::unique_ptr, or is it the case that if I use
std::shared_ptr, all handles should also be