this post was submitted on 29 Dec 2024
360 points (98.9% liked)

Programmer Humor

20028 readers
1409 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 2 years ago
MODERATORS
 
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 18 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

Because stuff can own other stuff and be owned at the same time. Also, arcane jackarsery.

Edit: if you want to give a function a pointer that it may change this may occur in a constructive way. I.e. replace an owned object.

[–] [email protected] 5 points 3 weeks ago (1 children)

Yeah... But it's usually a good practice to put a struct somewhere between your 30 levels of ownership.

Exceptions exist, but they are not very common. Also, in C++, operators overloading may help you if you keep needing to write code like this.

[–] [email protected] 3 points 3 weeks ago (1 children)

In C++ you should never have owning raw pointers. Unless you have a good reason™.

Raw pointers are great, but not for ownership.

[–] [email protected] 6 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

I just use unique_ptr 99% of the time

[–] [email protected] 4 points 3 weeks ago

And you should.

It even works for classes whose constructors your implementation cannot see, if you aren't a bitch about it.