this post was submitted on 21 Oct 2023
283 points (94.6% liked)
Programmer Humor
19822 readers
974 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
- Keep content in english
- No advertisements
- Posts must be related to programming or programmer topics
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
y <= MAX_INT
will never be false, since the loop will overflow and wrap around toMIN_INT
(You can escape code with
`backticks`
, and regular markdown rules)It will not "overflow". Signed integer overflow is undefined behavior. The compiler could remove the whole loop or do anything else imaginable (or not).
TIL!
I wonder how many languages out there do define what happens on integer overflow.
Languages with dynamic typing and implicit large-integer types, such as Python and Ruby, generally just convert to that large-integer type.
I figured Java would probably define the behavior in the JVM, but based on a quick web search it sounds like it probably doesn't by default, but does provide library methods to add or subtract safely.
Rust guarantees a panic by default, but provides library methods for wrapping, saturating, and unchecked (i.e. unsafely opting back in to undefined behavior).
Oh good call! What I was trying to do is more complex than I was thinking.
Hmmmmm.
(I should just test my code to make sure it works, but I haven't. Heh.)
Also, Lemmy escaped your angle bracket too. Back ticks don't seem to do the trick.
Inline: <
Or were you suggesting back ticks for some other purpose? (I did use back ticks in my first post in this thread.)
The backticks worked in the preview, and showed up correctly to start, but there must be a bug in the lemmy ui, since now it's double-escaped. No idea /shrug