169
top 31 comments
sorted by: hot top controversial new old
[-] CanadaPlus@lemmy.sdf.org 13 points 1 day ago* (last edited 1 day ago)

Eh, strict typing makes debugging way, way easier. Saint Grace brought us compilers for a reason. If all you have is assembly, you should start writing one.

[-] fschaupp@lemmy.ml 1 points 1 day ago

Ferris smirking You sure?

[-] xthexder@l.sw0.com 15 points 2 days ago

For NASA, data types don't matter when you're programming Voyager 1 and 45 years later it gets hit by an energy burst causing 3% of the RAM to become unusable, and it's transmitting gibberish. It's awesome they were able to recover it.

[-] garlicandonions@lemmy.world 6 points 1 day ago

It's documentation. I'm a strickler to type in python so later when I look at my code and go what does this do it's easier.

[-] livingcoder@programming.dev 30 points 2 days ago

When I learned Python I thought that not having a statically typed language was the way to go, but then it just became an issue when I was trying to ensure that everything was at least something like what I was expecting. Going back to statically typed languages even harder with Rust has been a dream. I love it.

[-] zenforyen@feddit.org 36 points 2 days ago

Python with type hints and mypy and ruff = <3

Large Python codebase without types = nightmare

[-] smiletolerantly@awful.systems 12 points 2 days ago

I'm too lazy to insert the "look what they need to mimic a fraction of our power" meme here, so.... Please imagine it instead.

I'm switching jobs in a couple of months, and I am SO glad to be leaving a (very well maintained!!) python codebase with type hints and mypy for a rust codebase.

It is just not the same.

[-] zenforyen@feddit.org 3 points 1 day ago* (last edited 1 day ago)

Nice! I'd love to use Rust at work, I was a Haskell guy for hobby things, rather recently switched to Rust for that, and I enjoy it a lot. Taking 80% of the good lessons from functional programming while staying performant and practical and just have nice tooling - whoever designed Rust are wise people who know what is important for happy developers.

My job is mainly C++, and if you have seen the bright side of life, it is difficult not to be frustrated by the language and tooling. I think C++ without clang-tidy is almost as horrible as Python without types and linters. Undefined behavior and foot guns everywhere!

[-] smiletolerantly@awful.systems 1 points 1 day ago

Oh yeah rust tooling is insanely good ootb

[-] SchwertImStein@lemmy.dbzer0.com 6 points 2 days ago
[-] Telorand@reddthat.com 36 points 3 days ago

Fr, though, duck typing in Python is one of my biggest annoyances.

[-] PotatoesFall@discuss.tchncs.de 21 points 3 days ago

I love duck typing! dynamic typing is my issue...

[-] firelizzard@programming.dev 7 points 2 days ago

“Assume it’s a map and treat like a map and then catch the type error if it’s not.” Paraphrased from actual advice by Guido on how you should write Python. Python isn’t a bad language but the philosophy that comes along with it is so fucked.

[-] ZephyrXero@lemmy.world 6 points 2 days ago

This is just preferring runtime validation instead of compile time validation.

[-] firelizzard@programming.dev 7 points 2 days ago

And relying on runtime validation is a horrific way to write production code

[-] manicdave@feddit.uk 2 points 2 days ago

Why though? I've genuinely never had a problem with it. If something is wrong, it was always going to be wrong. Why is it preferable to have to write a bunch of bolierplate than just deal with the stacktrace when you do encounter a type error?

[-] gedhrel@lemmy.world 1 points 1 day ago

I worked on OpenStack back in the day: millions of lines of untyped Python.

Let's say you've got an X509 certificate. You know you can probably pull the subject out of it - how? Were I using Java (for instance), the types would guide my IDE and make the whole thing discoverable. The prevalent wisdom at the time was that the repl was your friend. "Simply" instantiate an object in the repl then poke at it a bit.

And it's not just that kind of usability barrier. "Where is this used?" is a fantastic IDE tool for rapid code comprehension. It's essentially impossible to answer for a large Python codebase.

Don't get me wrong: python is still a great go-to tool for glue and handy cli tools. For large software projects, the absence of type enforcement is a major impediment to navigation, comprehension and speed of iteration.

[-] gedhrel@lemmy.world 1 points 1 day ago

And as for your specific question: typechecked code doesn't get to production with a type error; it won't compile. There's a common phrase, "left-shifting errors". It means catching bugs as early in the development cycle as possible. In terms of things like developer time (and patience), it's far more cost-effective to do so.

[-] darklamer@lemmy.dbzer0.com -1 points 2 days ago
[-] Magister@lemmy.world 26 points 3 days ago

nasm? the x86 assembler from the 90s?

[-] renegadespork@lemmy.jelliefrontier.net 6 points 2 days ago* (last edited 2 days ago)

let comment: String = String::from(“lol”);
println!(“{}”, comment);

[-] Bogasse@lemmy.ml 12 points 2 days ago* (last edited 2 days ago)
println!("{comment}");

C'mon, it's 2025!

[-] spacecadet@lemm.ee 0 points 2 days ago

Not inside a main function, won’t pass rust compiler check

Just a snippet from a bigger function.

[-] bodaciousFern@lemmy.dbzer0.com 3 points 2 days ago

I was actually tempted to try learning nasm for funsies a year or two ago until I discovered it doesn't support ARM processors 🥲

[-] firelizzard@programming.dev 12 points 2 days ago

Assembly languages are always architecture specific. Thats kind of their defining feature. Assembly is readable machine code.

[-] h4x0r@lemmy.dbzer0.com 6 points 2 days ago

nasm is an assembler though, not a 'languages', that only supports x86/x64. gas for example supports a wide range of architectures so you can write risc-v, arm, x64, etc.

[-] 0x0@lemmy.dbzer0.com -2 points 2 days ago

Are you arguing that assembly languages are not architecture-specific? I don't think that's the typical definition.

Nasm is an assembler, but it also represents a specific assembly language targeting x86 architectures.

Gas is an assembler of a higher order. It can emit code for many architectures, and thus it accepts many different architecture-specific assembly languages.

[-] Midnitte@beehaw.org 2 points 2 days ago* (last edited 2 days ago)

Not sure I've ever heard of nasm

this post was submitted on 01 Apr 2025
169 points (88.9% liked)

Programmer Humor

34803 readers
37 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS