this post was submitted on 17 Sep 2024
36 points (95.0% liked)

C++

1763 readers
1 users here now

The center for all discussion and news regarding C++.

Rules

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

The problem with c++ is that it allows people to do whatever they want. Turns out: people are dumb. Rust solved that problem. Nothing more, nothing less.

[–] [email protected] 8 points 1 month ago

I heavily disagree. C++ has a lot of problems but it's flexibility is not one of them.

Imo the biggest problem with C++ is that there are a dozens ways of doing the same thing. The std lib is not general and fast enough for everyone. Therefore it's not even "standard" .

I have seen many conferences of a proposed "cpp2" like syntax that breaks abi but imo it's the best way forward.

[–] [email protected] -3 points 1 month ago (2 children)

Rust still allows people to do (basically) whatever they want via unsafe blocks.

[–] [email protected] 8 points 1 month ago (2 children)

Yeah but I have written a lot of Rust and I have yet to use a single unsafe block.

Saying "but.. unsafe!" is like saying Python isn't memory safe because it has ctypes, or Go isn't memory safe because of its unsafe package.

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

You don't have to use unsafe C++ functions either

C++ is technically safe if you follow best practices

The issue, to me, is that people learn older versions of the language first, and aren't aware of the better ways of doing stuff.

IMO people should learn the latest C++ version first, and only look at the older types of implementation when they come across them

[–] [email protected] 2 points 1 month ago (1 children)

C++ is technically safe if you follow best practices

Yeah but it's virtually impossible to reliably follow best practices. The compiler won't tell you when you're invoking UB and there is a lot of potential UB in C++.

So in practice it is not at all safe.

[–] [email protected] 4 points 1 month ago

I agree

I was only adding my opinion (that people should try to always use the latest version of C++, which is inherently safer, but still not 100% safe)

[–] [email protected] -5 points 1 month ago

See my reply to funtrek's reply.

[–] [email protected] 7 points 1 month ago (1 children)

Sure, but you have to explicitly enable this feature. In c++ you can use the oldest shit from twenty years ago and your compiler happily does its job. All my c++ books are full of "you shouldn’t use xy as it is deemed unsafe now, but of course you still can".

[–] [email protected] -4 points 1 month ago (1 children)

If a "safe C++" proposal truly proposes a safe subset, then yes your C++ code would have to opt-in to doing unsafe things. For the purposes of this discussion of a safe subset ... the point is moot.

[–] [email protected] 6 points 1 month ago (1 children)

It's not moot. The Safe C++ is opt-in to safety. It has to be because otherwise it wouldn't be compatible with existing C++.

[–] [email protected] -3 points 1 month ago* (last edited 1 month ago)

That's a laudable difference /s. Using Rust is also an "opt-in" option.