Conversation

so I had never really thought too hard about C++'s unique_ptr abstraction, except to be vaguely annoyed that it so obviously failed to enforce anything remotely resembling what its name appears to promise 1/5
7
60
anyhow, recently I needed to implement a compiler for the language that and I are using for our spring compiler class, and I decided to use C++ and also to take unique_ptr seriously in the implementation 2/5
1
18
the other data structures from the library that I'm using are vector and unordered_map, which I already liked perfectly well, they are both very nice abstractions 3/5
1
15
anyhow, once I understood that unique_ptr meant nothing like its name but rather something like auto_free_pointer, the pieces sort of fell into place and I experienced almost no memory safety bugs while implementing the compiler, nor has afl-fuzz found any so far 4/5
6
47
this is all despite my being a thoroughly mediocre C++ programmer. anyhow this story has no real point except that unique_ptr is actually pretty cool and useful, which I had not expected 5/5
11
97
The other use case is when using traits as objects. It's a lot more common to use enums (sum types) or traits as type bounds on generics. The reason you'd use trait objects over enums is extensibility (not a limited set of types) and it can keep code size smaller than generics.
1
1
It's usually a lot more natural to use enums and generics. I never found many use cases for trait objects when writing application code. It comes up when making a library that needs to be extensible. Could use them simply to reduce code size but you'd usually just need &Trait.
1
1
Show replies