this post was submitted on 10 Oct 2024
47 points (85.1% liked)

Programming

17189 readers
476 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 [email protected]



founded 1 year ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] JackbyDev 1 points 4 days ago (2 children)

Is there any reason an OO language couldn't have a borrow checker? Sure, it would be wildly more complex to implement but I don't see how it's impossible.

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

OO languages typically use garbage collector. The main purpose of the borrow checker is to resolve the ambiguity of who is responsible for deallocating the data.

In GC languages, there’s usually no such ambiguity. The GC takes care of it.

[–] JackbyDev 3 points 4 days ago
[–] nous 1 points 4 days ago

I would argue that rust has a very strong OO feature set (it just lacks inheritance which is the worst OO feature IMO). It is not seen as an OOP language as it also has a very strong functional and procedural feature set as well and does not favor one over the other letting you code in any style that best fits the problem you have.

So I would not say OO and a borrow checker are impossible or even hard. What makes less sense is a GC and the borrow checker. Though there are some use cases for having a GC for a subset of a program.