863
top 20 comments
sorted by: hot top controversial new old
[-] moseschrute@lemmy.world 63 points 6 days ago* (last edited 5 days ago)

You think timezones are annoying? Try handling metrics that use imperial and metric, need to be rounded to different precisions across a large system, and are sometimes recorded in a different unit than it's viewed in. Slap some floating point error on there, and you got yourself a fun time.

I spent all day working on bug where backend was categorizing 19.9999 as falling between <20, but frontend was rounding it to 20 and categorizing it as >=20.

Edit: just to be clear, I don’t really think this is more difficult than date/time. But it does remind me a lot of solving date/time issues.

[-] FunctionallyLiterate@lemmy.ca 27 points 6 days ago
[-] capuccino@lemmy.world 7 points 6 days ago* (last edited 6 days ago)

I remember talking about ths in early semesters of Software Engineer career in college

[-] azi@mander.xyz 19 points 6 days ago

hey at least once your code is correct it'll stay that way. You won't have to deal with things like old and new versions of your program disagreeing on what time it was in Iran for the last month and a half of 1978

[-] sznowicki@lemmy.world 12 points 6 days ago
[-] _hovi_@lemmy.world 5 points 6 days ago

Thanks, interesting read

[-] applebusch 8 points 5 days ago

This is why, in any competent software dealing with physics in any way, it is always metric under the hood. Someone wants to see a quantity in some stupid freedom units? Fine sure convert it for them, but internally everything should be metric. Physics is hard enough, there's no reason to make it worse with an inconsistent unit system with built in footguns somehow.

[-] moseschrute@lemmy.world 2 points 5 days ago

I agree, storing in a consistent unit is the way. That doesn’t solve conversion/rounding issues, but it does simplify things.

Though you can run into floating point errors when editing in one unit vs storing in another. For example, maybe the user entered 2 in unit A, then it’s converted to unit B and stored in the db. However, when it’s converted back to unit A, it’s 1.999999. Fortunately rounding fixes this. We say unit A and B get 2 decimals of precision, and 1.999999 becomes 2.00.

[-] iglou@programming.dev 3 points 5 days ago

I would say your biggest issue here is needing precise decimal point computations and using imprecise data types. Any software that requires precision in the decimals needs to use types that are made for precise decimals. No floating point error.

[-] moseschrute@lemmy.world 1 points 5 days ago

For this specific project, I need max 2-3 decimal places of precision. So rounding really fixes all the issues. It’s more that we’re preventing the user from seeing awkward decimals. We aren’t doing rocket science. But understanding what metrics need what precision, and sometimes the same metric needs a different precision in different contexts.

[-] Whelks_chance@lemmy.world 15 points 6 days ago

Tom Scott's video is about to do the rounds again then

[-] luciferofastora@feddit.org 6 points 5 days ago

Oh damn, I forgot to check which of my scheduled tasks were set to UTC, which were set to local time and whether they adjust automatically and what schedule the upstream tasks by different teams run on again.

Oh well, nobody cried about anything breaking yet, so I might be in the clear. For now.

[-] panda_abyss@lemmy.ca 7 points 6 days ago

Reading the pytz time zone database is an insane and engaging read.

Nobody is ever going to solve that problem.

[-] Cevilia 5 points 5 days ago

Days since last timezone issue: -0.0416666666667

[-] python@lemmy.world 3 points 5 days ago

The switch to winter time was last sunday, it's been a fun week at work so far.

[-] humanspiral@lemmy.ca 5 points 5 days ago

One of the worst things about having DST at all is that it is not standardized through world. North America has not switched yet, and people making these announcements make me think my phone is broken.

[-] locuester@lemmy.zip 1 points 5 days ago

Would be better as 4,294,967,295 instead of -1.

[-] fahfahfahfah@lemmy.billiam.net 2 points 5 days ago* (last edited 5 days ago)

The original post would be the result of subtracting the same date in two different time zones that are currently in different days. Whereas what you’re saying is basically just an under flow error.

[-] locuester@lemmy.zip 2 points 5 days ago

What I’m saying is just a level deeper for comp sci people. It’s the same thing, but expressed on a 32-bit unsigned integer.

Same result. Deeper joke.

[-] AmazingAwesomator@lemmy.world 1 points 6 days ago
this post was submitted on 28 Oct 2025
863 points (100.0% liked)

Programmer Humor

27175 readers
1275 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