this post was submitted on 28 Aug 2023
54 points (96.6% liked)

Programming

17048 readers
806 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities [email protected]



founded 1 year ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 6 points 1 year ago (2 children)

Couldn't this be solved by having push_back being an inline function (or at least the check on capacity being inlined and the rest of the non-trivial part being in a sub non-inline function)?

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

I don't know about C++, but in Rust the push is inline, and still doesn't always optimize checks away due to an annoying edge case: integer overflow. Reserving (old_len + new_len) could give you a smaller buffer than new_len. The optimizer sees it and is pedantic about it.

[–] [email protected] 1 points 1 year ago (1 children)

In C++ integer overflow is UB so this edge case cannot exist

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

Only signed overflow. size_t is unsigned.

[–] [email protected] 1 points 1 year ago* (last edited 1 year ago)

That's totally right but I thought you were talking about signed numbers since you said “integer overflow”. I forgot that len is usually unsigned in C++.

[–] [email protected] 0 points 1 year ago (1 children)

Ok, but why did you not use emplace?

[–] [email protected] 1 points 1 year ago

emplace controls the construction of the object added to the collection. It's also important but not related to the problem exposed by OP which is “how to remove the capacity check when we know statically that there is enough space”.