this post was submitted on 18 Feb 2025
8 points (100.0% liked)
C++
2130 readers
1 users here now
The center for all discussion and news regarding C++.
Rules
- Respect instance rules.
- Don't be a jerk.
- Please keep all posts related to C++.
founded 2 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
Because that's not the sensible route in the future, whether we like it or not. Hardened STL is being announced in the papers as "we are going to start with these silly one-line fixes that in theory should perturb no one, but as we iterate over this we're gonna start breaking things", which is not what you want to hear from the default.
One good example: placing enforced bounds check into the
operator[]
ofstd::array<>
of all places. People keep telling me that I should be using std::array instead of normal C arrays, but then punish me for using std::array? That ends up making people revert to the True Old Ways That Work (aka: C arrays).Bounds checks are not punishing you. Obviously the right way to do this would be to make
operator[]
be bounds checked by default but only if you use-std=c++29
or whatever, and then also add a.at_unchecked()
method for when you want to opt out of the bounds checks.What kind of barbarism is that?
Doing that kind of split would kill genericity (more than it already is). If I'm using
[]
is because what I want is, more or less, to just access the value; not to maybe randomly and without any kind of source-level control or projected time/space boundaries go to the blockchain to check if the Rust devs are in the mood today to have blessed the given statement with the arguments given.Frick. At least give me something like
[checked(5)]
or[unchecked(5)]
for a more natural syntax. The more considering it has been possible to add compile-time checked access with something like[integral_constant<size_t,5>{}]
since at least C++03! It just needs someone to propose a standardized notation shortcut. Or if there was some way to inquire orstatic_assert
that the checks on the natural syntax are actually elided if I'm doing them myself elsewhere. But at it stands, uglifying the syntax is the worst of all worlds.What on earth are you talking about? I honestly can't even understand what objection you're trying to make.
Wait, wait! Are you under the impression that
.at()
is a function call andoperator[]
is ...not? What?Nobody mentioned Rust. This is a C++ community.