this post was submitted on 19 Mar 2024
145 points (92.9% liked)

Programming

17540 readers
79 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



founded 2 years ago
MODERATORS
 

Python is memory safe? Can't you access/address memory with C bindings?

you are viewing a single comment's thread
view the rest of the comments
[–] Dark_Arc@social.packetloss.gg 110 points 8 months ago (24 children)

Python is memory safe? Can't you access/address memory with C bindings?

You can do that in basically any language. Rust even has the ability to break out of its safeguards and write unsafe Rust code.

"Memory safety" in this context is more about the defaults and how easy it is to write unsafe code accidentally.

[–] Traister101 31 points 8 months ago (21 children)

Unsafe Rust really just let's you play with pointers

This is the entirety of what Unsafe Rust allows

  • Dereference a raw pointer
  • Call an unsafe function or method
  • Access or modify a mutable static variable
  • Implement an unsafe trait
  • Access fields of unions
[–] declination@programming.dev 17 points 8 months ago* (last edited 8 months ago) (15 children)

I'm still onboard with rust as being better than C, however...

My understanding is that it is considerably harder to correctly write unsafe rust than it is to correctly write c, because if you accidentally violate any of safe rust's guaranteed invariants in an unsafe block, things go bananas.

[–] Traister101 10 points 8 months ago* (last edited 8 months ago) (2 children)

Yes Rust is harder to write than C, that's basically by design as it's due to the statically guaranteed memory safety. That's pretty magical. C doesn't have that and neither does C++ even with smart pointers and such. Rusts unsafe keyword is poorly named, what it actually does is tell the compiler that you the programmer guarantee Rusts rules are upheld within the unsafe block.

For example

Access or modify a mutable static variable

That is a global, that's incredibly hard to impossible to statically prove it's safely done, so you have to do it in an unsafe block. So you violating Rusts rules within an unsafe block is actually using the unsafe block wrong. That's not what it's for

[–] Solemarc@lemmy.world 2 points 8 months ago* (last edited 8 months ago)

I remember watching a video of someone writing C code and making the same thing in unsafe rust. While the C code worked just fine the rust code had UB in it and was compiled to a different set of instructions.

Unsafe rust expects you to uphold the same guarantees that normal rust does and so the compiler will make all the same optimisations it would if the code wasn't unsafe and this caused UB in the example rust code when optimised for performance. It worked just fine on the debug build, but that's UB for you.

[–] Fal@yiffit.net -1 points 8 months ago (2 children)

Yes Rust is harder to write than C

I would totally argue with this. Rust is way easier to write than C

[–] Traister101 2 points 8 months ago (2 children)

I'd probably say it depends but I'm no Rust expert and I have no direct experience with C (though quite familiar with C++).

Basically I'd expect writing C to be easy, but not safe. IE you can quickly and easily write C that compiles but has runtime issues. Rust for the most part will catch everything but logic issues during/before compilation meaning once the program runs you'll have very high confidence in it's runtime behavior leading to time spent "fighting the compiler" instead of figuring out wtf is going wrong at runtime.

[–] Traister101 2 points 8 months ago

I think primarily I don't really care to argue about if it's harder to write or not since it doesn't really matter. I think the pros Rust provides are worth all it's cons

[–] Fal@yiffit.net -2 points 8 months ago

IE you can quickly and easily write C that compiles but has runtime issues.

So what's "easy" about it then? Just getting something to compile? That's not a very good measure of "easyness".

[–] vext01@lemmy.sdf.org 2 points 8 months ago (1 children)

I agree for the most part, but writing data structures with shared mutable state can be a total pain in Rust.

[–] Fal@yiffit.net -1 points 8 months ago (1 children)

How so? That's like, the thing that makes rust awesome to write.

[–] vext01@lemmy.sdf.org 1 points 8 months ago (1 children)

It's hard to get those kinds of data structures through the borrow checker.

Try writing a doubly linked list.

[–] Fal@yiffit.net -3 points 8 months ago (1 children)

It's because it's hard to make them correct. It's not any harder to write it in rust than in C. Just C lets you do it wrong

[–] vext01@lemmy.sdf.org 1 points 8 months ago (1 children)

That's not right.

Try and write a mutable doubly linked list in Rust and you will find that it's problematic for the borrow checker.

Search online and you will find solutions that work around this using 'RefCell' (to delegate mutable borrows to runtime), or raw pointers with 'unsafe'.

[–] calcopiritus@lemmy.world 0 points 8 months ago (1 children)

Both RefCell and unsafe are features of the language. That's like saying python's OOP sucks if you don't use the class keyword.

[–] vext01@lemmy.sdf.org 1 points 8 months ago

I'm not saying it sucks. I'm saying it can be less straight-forward than conventional languages, even for experienced programmers.

The borrow checker is fantastic, but there's no doubt that it requires a new way of thinking if you've never seen Rust before.

load more comments (12 replies)
load more comments (17 replies)
load more comments (19 replies)