How rust forces you to respect memory

  Рет қаралды 36,504

Jacob Pradels

Jacob Pradels

Күн бұрын

Пікірлер: 219
@danilfun
@danilfun Жыл бұрын
Big thing missing from the video is C++ objects, which could also be automatically destructed, could also be moved, could also be referenced. It's also free. On the first glance it seems like rust is no better than C++. Critical missing information here is that rust enforces these constraints, while C++ does not. I think this is the main reason why rust is better, object ownership is secondary.
@indiesigi7807
@indiesigi7807 Жыл бұрын
I just don't consider safer as better. it's such a reductionist view. c++ is better in every way except in explicit safety. People are gonna write horrible code thinking it's safe and efficient and it's most likely not. Enums are an example where the largest variant will dictate the allocated size per entry. It looks very elegant but it's the opposite of efficient. Rust is full of this and you need to know and be mindful about it or you'll write the most bloated inefficient programs ever. If rust picks up brace yourself for mountains of truly horrible code with a certified quality label.
@angelcaru
@angelcaru 9 ай бұрын
@@indiesigi7807 How are enums the opposite of efficient? For that usecase, you WILL need to use the maximum variant size (unless you want to suffer with malloc). The direct translation to C/C++ has the same problem: ```rust enum E { A(i32, i32), B(u64, u64) } ``` ```c typedef enum { E_A, E_B, } E_Type; typedef struct { E_Type type; union { struct { int a_first, a_second }; struct { uint64_t b_first, b_second; } }; } E; ```
@mk72v2oq
@mk72v2oq 6 ай бұрын
The main feature of Rust is the borrow checker. C++ has unique_ptr and shared_ptr, which are analogous to owned value and Arc in Rust, but that's where C++ safety ends. In C++ invalid references are allowed, you can have multiple mutable references, can hold reference to a no longer existing value etc. C++ doesn't have any mechanism to avoid it. That's why things like use-after-free are so common in C++. Rust does provide safety guarantees for references. All references are always valid, you can't have multiple mutable references, references can't outlive values. That's why it's practically impossible to produce memory-related bugs.
@Sacred-Lotus
@Sacred-Lotus 4 ай бұрын
​@@mk72v2oqVery Good explanation. I can see why rust ensure memory safety:only *One* immutable Reference is allowed for each Object/Functor. They will be destroyed when the ref counting reaches *Zero* (I.e. Ref to obj no longer in use).
@artxiom
@artxiom 2 ай бұрын
@@indiesigi7807 Rust isn't only safer, it's tooling is way better, meta-programming way more powerful, it has better (and way easier) iterators, better functional programming support, traits, abstract data types, labeled loops, almost everything is an expression (and thus composable), native async support, etc., etc. I have to find yet one(!) single thing that C++ does better than Rust!? I've been programming in C++ for over 20 years and just recently started using Rust: it's just way simpler, faster and easier to work with. It's not unusual that I can express the same algorithm with half the code in Rust.
@hcn6708
@hcn6708 7 ай бұрын
"Ok, so hear me out on this: Rust" _mixed reaction from the crowd_
@DuskyDaily
@DuskyDaily Жыл бұрын
This is amazing but not the main reason why most people love Rust. Rust like used all the good practices that have been developed by the programming community and fit into a single language, almost each Rust feature could be a reason of its own to like it. The compiler errors are amazing. Rust Enums featuring algebraic type system, offering amazing error handling system with Result type. No null values with Option types, completely eliminating an entire field of problems. It isn't object oriented but still have interfaces (known as traits) and type methods, but no inheritance (which was like the part used badly in other OO languages). And I could just go on and on. Rust took all good parts from different languages, coding styles and paradigms, but removing the bad parts about em. Rust is arguably the best one yet, still not perfect and still improving. And personally I found Rust as the best middle ground from "close to procedural" but still very expressive with functional programming paradigm.
@lavonov
@lavonov 3 ай бұрын
I completely agree, rust is a language designed by experience
@pshr2447
@pshr2447 Жыл бұрын
So doesn't Smart Pointers in C++ also solve this particular problem of memory leak when variables are going out of scope? Like if we have a pointer and enclose it in a class then if it goes out of scope it's destructor will be called which will initiate the cleanup code required to free up the memory. Is it not a good enough solution or am i missing something?
@alvaroluis5368
@alvaroluis5368 Жыл бұрын
Not only smart pointers. std::vector is basically an array of variable length in heap that gets freed when out of scope. It is also used in std::string and in every class that frees up resources on its destructor. It's called RAII and it was a thing in c++ before Rust existed.
@mghinto
@mghinto 8 ай бұрын
C++'s safety is an afterthought and is all opt in, while Rust's safety is inherent to the language and is all opt out. That makes a big difference and reduces what code you have to consider when something goes wrong. Also, if your rust program compiles, you can be pretty confident that it will work before you even run it.
@starllama2149
@starllama2149 6 ай бұрын
@@mghinto I don't get this mindset though? Nobody is forcing you to use the unsafe c++. Nobody is also forcing you to not use the unsafe keyword in rust. C++ is plenty fine enough. RAII is enough.
@jcm2606
@jcm2606 3 ай бұрын
@@starllama2149 The problem is that RAII in C++ is not mutually exclusive to the old ways of doing things. Modern C++ still allows you to freely allocate memory using malloc/new, modern C++ still allows you to get a raw pointer from a smart pointer, modern C++ still allows you to mutate a value through _any_ pointer pointing to a non-const value, smart or not. You may scoff and say something along the lines of "anybody who knows what they're doing wouldn't do this", and yes, you're right. The problem is not everybody knows what they're doing, and even those who know what they're doing can have a lapse in judgement and make a mistake somewhere that proliferates and leads to swaths of unsafe code. It's not enough to just trust that everybody and anybody knows what they're doing, which is what Rust understands and IMO gets right with its safe-by-default design.
@rafagd
@rafagd 3 ай бұрын
It's a question of opt-in vs opt-out. In C++, you need to actively seek the safe pattern but doing magic with pointers is often easier and less verbose. In Rust, the ownership is enforced and you need to explicitly opt-out of it to be able to play around with memory freely. Which one is a better option depends on your use-case.
@rafagd
@rafagd 3 ай бұрын
Main is a bit of a bad example because the OS is supposed to free the memory from your program anyway. Leaks are more of a constantly running program thing.
@mr.rabbit5642
@mr.rabbit5642 2 ай бұрын
True ^
@julesoscar8921
@julesoscar8921 2 ай бұрын
Sure but when you allocate in a hot function, you don't want your program to leak anyway
@ErikBongers
@ErikBongers 10 ай бұрын
Nitpicking, but rust wouldn't pop arr from the stack after the move. It's the compiler that marks arr as no longer valid. It's a compile time check, not a runtime action.
@MikeDawson1
@MikeDawson1 Жыл бұрын
isn't this just like an std::vector though?
@thetos
@thetos 2 ай бұрын
I'd like to add onto the garbage collector explanation that there are multiple types of garbage collection strategies, Java has a mark and sweep strategy, which marks memory accessible from the running program and sweeps the rest at regular intervals. Other languages like PHP use reference counting, where memory is reclaimed as soon as nothing points to it. They each have their advantages and disadvantages.
@darrellplank4518
@darrellplank4518 Жыл бұрын
Generally well explained but left out are the MANY corollaries of Rust's philosophy such as standing on your head to get two objects that point to each other and the difficulties inherent in graphs. That you have to drag in special crates just to have a mutable global. New concepts entirely like lifetimes need to be understood, etc., etc.. I realize there are solutions to all this, but Rust requires a lot more out of the programmer than C++ does - it just does. I also realize that most Rust programmers would say that's a good thing and most of the time I'd be with them on that opinion, but to leave all this out will really not describe to a C++ programmer the difficulty of adjusting to Rust. This makes it seem like ownership is a no-brainer and "that's all there is" when, in fact, the devil's in the details.
@swapode
@swapode Ай бұрын
Yes, Rust has a steeper learning curve than C++. On the other hand it's a lot less you need to learn to actually be competent. And Rust will let you know that you still have to learn while C++ will happily pretend like absolute garbage is fine. My favorite part of pretty much every C++ conference is when some speaker presents an innocent looking piece of code where even committee members in the audience can't tell why it's wrong.
@shadergz
@shadergz Жыл бұрын
C++ Smart pointers: I don't exist**
@RetroAndChill
@RetroAndChill 2 ай бұрын
Neither does std::vector apparently
@1n4f4bl3
@1n4f4bl3 3 ай бұрын
Mastering C isn't just about writing syntactically correct code--it's about wielding an unparalleled command over memory management. True C programmers understand that the heart of the language lies in navigating the delicate intricacies of dynamic allocation, pointers, and memory deallocation. Efficient memory management is the core of performance, reliability, and scalability. Without it, you're merely scripting. To call oneself a C coder without this expertise is to misunderstand the true power of the language.
@RenderingUser
@RenderingUser 3 ай бұрын
C programmers when assembly language wields a million times more command over memory
@1n4f4bl3
@1n4f4bl3 3 ай бұрын
@@RenderingUser Assembly is like that old-school mercenary who gets the job done, but you've got to personally guide every bullet. C? It's the guy who follows orders but still might blow up half the team. Rust? Oh, Rust is that overly cautious rookie who's like, 'You sure you wanna fire that? You might hurt yourself.' Meanwhile, Assembly’s already smoking a cigar and counting the cash. Efficient, baby!
@RenderingUser
@RenderingUser 3 ай бұрын
@@1n4f4bl3 Rust isnt the rookie. its more like the guy that has a 3000 page book of stratagies and wont let a plan go into action unless its detailed to perfection
@1n4f4bl3
@1n4f4bl3 3 ай бұрын
@@RenderingUser Oh yeah, that language nobody used to care about. Now it's like the cool kid at the programming party, sipping its memory-safe latte while C and C++ sit in the corner reminiscing about the good ol' days when nobody cared if things blew up. Rust? Please. It’s like the hipster of languages -- 'I was safe before it was cool!'
@stefanalecu9532
@stefanalecu9532 2 ай бұрын
​@@1n4f4bl3 nice, casually erasing the contributions that Eiffel and Ada had on Rust. Like a true hipster would
@henning4327
@henning4327 2 ай бұрын
When you say "Rust might be the best programming language", you blatantly ignore the functional ones
@jacobpradels
@jacobpradels 2 ай бұрын
Good point, which functional language do you think would be in contention?
@henning4327
@henning4327 2 ай бұрын
@jacobpradels For static verification, many dependently typed languages like Agda are well-suited. All functional programming languages are of course memory-safe, but there are some which actually have comparable performance to procedural languages and do not necessarily use a garbage collector. I think Roc is one of them. PS: Although my initial comment sounded a bit harsh, I enjoyed your video nonetheless, I was just taken a bit by surprise by your opener ^^
Жыл бұрын
Surely it is because I’m an old fashioned C/C++ programmer and I can’t still see the beauty of this ownership paradigm, but right now I can only think about how annoyingly painful would be for me to try coding about anything in Rust, I already have a headache just from thinking about it. I can definitely see the advantages of of the compile time analysis and strict memory management Rust provides, but I’m afraid it comes with a cost in flexibility and usability that may be too high for certain situations.
@RenderingUser
@RenderingUser 3 ай бұрын
I have a headache thinking of the uncertainty from languages that don't have a borrow checker. On rust I hardly even have to run the program. If it compiles, it works.
@LaysarOwO
@LaysarOwO 3 ай бұрын
exact opposite for me i love borrow checker and just thinking about raw pointers gives me a headache its all a matter of what youre used to, really
@pyyrr
@pyyrr 2 ай бұрын
yeah, with c and c++ you get to focus on the problem rather than the borrow checker
@RenderingUser
@RenderingUser 2 ай бұрын
@@pyyrr you only focus on the borrow checker because you keep actively fighting against it. Learning to code involves learning the best design patters for a language too.
@pyyrr
@pyyrr 2 ай бұрын
@@RenderingUser i dont fight against it. i just use c++, that solves the problem.
@pshr2447
@pshr2447 Жыл бұрын
Great video btw actually made me so curious that i would like to learn more about rust
@CHURCHISAWESUM
@CHURCHISAWESUM 3 ай бұрын
Unfortunately I’m stuck modifying a C++ codebase, it’s a shame because I’d love to use Rust but I don’t have the time to rewrite this entire framework in Rust 😂
@AyrtonGomesz
@AyrtonGomesz 2 ай бұрын
Amem brother. Tell these guys why most ML, LLM and AI codebases are C++ rather than rust
@yazode
@yazode Жыл бұрын
Thank you for the great video!! what software do you use to make such illustrations?
@wendell_parham
@wendell_parham 2 ай бұрын
I'm building a programming language dose dose reference counting at the compilation level public and static -- exposed one immutable the other not , local -- stack and private I maintain memory buy counting references during compilation when references hit 0 it's unallocated (done right after the last reference is nulled ) it dose have self-referenece issues of which the complier will have to figure out
@uvsmtid
@uvsmtid Ай бұрын
Java would NOT leave array on the heap in these examples. See "escape analysis". Java would work the same way as Rust. Of course, in compicated cases, array reference may eventually escape few scopes away and be left on the heap, but we can find equivalent example for Rust when this happens too.
@vlc-cosplayer
@vlc-cosplayer 2 ай бұрын
"Rust is good because..." "Erhm achshually..." It's the amps vs volts debate all over 💀
@spaceplex5079
@spaceplex5079 3 ай бұрын
best visualization of memory i've seen
@liam.3d265
@liam.3d265 2 ай бұрын
what software do you use to animate this? i would like to know
@jacobpradels
@jacobpradels 2 ай бұрын
Microsoft Powerpoint haha
@andreykalmatskiy2656
@andreykalmatskiy2656 3 күн бұрын
These "borrow checks" work only for the most primitive cases around stack allocated flat data structures. Real applications use mostly arrays of polymorphic objects, not integers, And these objects reference one another with cross-references. How Rust handles these data structures, how it prevents memory leaks in these cases?
@bity-bite
@bity-bite 2 ай бұрын
Nice video, I'd like to share how this 2:53 is similar to how C#'s span works, the span is automatically freed when it exits the scope. { var array = new int[10].AsSpan(); } // The array is dead now, no heap allocations, no GC. 🚀 You could also just allocate on the stack (via stackalloc), but that is not a good idea for bigger arrays.
@MenelBOT
@MenelBOT 2 ай бұрын
So I'm not getting something, why not just make arr2 point to arr, and since arr is being pointed to it doesn't go out of scope until arr2 does too?
@אקרמיצאלח
@אקרמיצאלח 2 ай бұрын
becuase in rust a block of memory has one owner. if you want that same block of memory to have two owners, or shared ownership you can use rc or arc (for multithreaded) it gets even weirder because this type of owner ship gives you a read only access type. if you need to be mutable as well you need to use refcell, and when using arc (for multithreaded) you usually would use a mutex, theres rwlock which i never used so idk about it theres probably alot more.
@nedotraxxxx
@nedotraxxxx 3 ай бұрын
Powerful and well designed language 🦀
@xyzabc123-o1l
@xyzabc123-o1l 2 ай бұрын
first, they told me to respect ring zero. then they told me to respect women. now they tell me to respect memory. but there was no one left to respect me
@everestp8
@everestp8 2 ай бұрын
Why in Java, when "arr" is popped out of the stack, does the system not automatcally frees the memory referenced by "arr" in the heap?
@everestp8
@everestp8 2 ай бұрын
Oh... I get It now
@everestp8
@everestp8 2 ай бұрын
But the system could store a value in the heap along with the allocated data to store the number of references to that address and every time the ownership is duplicated the number increases, every time a reference is released, the number decreases and when the last reference is released with the value equal to 1, the heap data would be deallocated once and for all. What would be the consequences of implementing this and what problems that a gc would solve that It can not solve?
@everestp8
@everestp8 2 ай бұрын
Oh, there is a name for It: "reference counting". GPT helped me with that
@zeropointer125
@zeropointer125 Жыл бұрын
Wait... but c++ does pretty much the same things. Only difference is = copies by default and you have to explicitly std::move
@RenderingUser
@RenderingUser 3 ай бұрын
Which is precisely the issue. Sane defaults need to exist
@NEWDIABLO96
@NEWDIABLO96 2 ай бұрын
Copies by default only if copy constructor or copy assignment is defined for the object, otherwise it is a forbidden operation
@zeropointer125
@zeropointer125 2 ай бұрын
@@NEWDIABLO96 I mean most of the time those operators are defined by default. I believe it's only not defined if a custom destructor is defined.
@CliveStewart-bq3od
@CliveStewart-bq3od 9 ай бұрын
Very clear and understanding .. you must do more videos like this
@tru2thastyle
@tru2thastyle 6 ай бұрын
It can’t be the best unless it does all that, but was simple. Instead it’s complex with a steep learning curve. That’s not a small issue, people don’t run companies don’t understand the value of being able to move quickly.
@maelstrom254
@maelstrom254 Жыл бұрын
C++ works exactly as described in the video 😂
@Biriadan
@Biriadan 2 ай бұрын
Shared pointers have a slightly higher runtime cost than the ownership model since a counter has to be incremented / decremented with every call. The upside is that shared pointers and weak pointers are wayyyy less restrictive.
@zanagi
@zanagi 2 ай бұрын
@@Biriadan can you clarify what do you mean by restrictive? also the last part he explained sounds just like unique_ptr and std::move to me. well I guess not if its owned by multiple at the same time.
@Biriadan
@Biriadan 2 ай бұрын
@@zanagi I can have multiple pointers to the same block of memory and be able to mutate it from any of them without any special constructs needed at all. I think to get the same write many behavior you need to use special constructs in rust like rc and arc.
@SamualN
@SamualN 8 ай бұрын
how does this apply when using async though?
@trashcan3958
@trashcan3958 3 ай бұрын
I know its off topic, but your animations are really smooth. I especially liked the transition between blocks of code. How did you make those?
@zanagi
@zanagi 2 ай бұрын
i dont get it. unique_ptr also can have std::move so whats different?.
@cluelessProgrammer1
@cluelessProgrammer1 2 ай бұрын
Where can you learn this kind of topic? I feel like, i'm still missing a lot of information that i should've know. I want to understand more the java lang. Where should i start?
@jacobpradels
@jacobpradels 2 ай бұрын
@@cluelessProgrammer1 google or talk to ChatGPT. “How does Java handle memory management?” Then compare it to other languages. Likely the answer you get will prompt more questions “What is a stack?” “What is a heap?” “How is memory allocated on a stack vs heap?” If you just ask a few questions then ask about the things you don’t understand you can learn a ton
@MariusSchwendtmayer
@MariusSchwendtmayer Ай бұрын
I prefere c cause any type has the freedom of being entirely allocated on the stack, static heap or dynamic heap. I also like treating bools like ints and inlining my logic into jump tables using 2d matrix of of function pointers so false false is [0, 0] true false [1, 0] or true + true and false + true is [2, 1] I think rust is great for low level embedded applications but not for drivers and systems programming.
@David-gu8hv
@David-gu8hv 3 ай бұрын
Is this the same concept as C++ smart pointers?
@kakesinfo
@kakesinfo 3 ай бұрын
In C++20 there is ownership with smart pointers
@oglothenerd
@oglothenerd Ай бұрын
2:10 When capitalism solves programming problems.
@naturallyinterested7569
@naturallyinterested7569 2 күн бұрын
I have zero respect for memory.
@dmitry_rellek
@dmitry_rellek 2 ай бұрын
Where is C++ comparison?
@nightfox6738
@nightfox6738 3 ай бұрын
A better solution is to combine rust's approach with reference counting.
@georgemarkas
@georgemarkas 2 ай бұрын
Hipsters performing mental gymnastics to not use valgrind smh
@quentinasparria7207
@quentinasparria7207 2 ай бұрын
fr, valgrind is the cure
@test-rj2vl
@test-rj2vl 2 ай бұрын
Idea is good. If only they could adopt Java syntax to make it more programmer friendly it would be perfect.
@alvaroluis5368
@alvaroluis5368 Жыл бұрын
This concept is called RAII and you could do it in C++ years before Rust existed
@adityatripathi9125
@adityatripathi9125 4 ай бұрын
yes, infact Rust borrowed it from C++ but the fact that Rust has it as a 'default' mechanism it what is better (and safer) IMO.
@sot_dev
@sot_dev 3 ай бұрын
right, but you might forget to handle this in C++ unlike Rust it's done automatically
@AyrtonGomesz
@AyrtonGomesz 2 ай бұрын
all of your points are skill issues at best
@BoardGameMaker4108
@BoardGameMaker4108 2 ай бұрын
@@sot_dev RAII is automatic in C++ though. That's the whole point, you don't have to think about it. If your class has a smart pointer, or other object with RAII, the class will have it's destructor automatically generated. The only time you need to write destructors yourself is when wrapping C code, just like Rust.
@sot_dev
@sot_dev 2 ай бұрын
​​@@BoardGameMaker4108 ah nice! thanks for the upd
@Sollace
@Sollace 2 ай бұрын
So the tl;dr is Rust generates the free() so you don't have to
@whereispie
@whereispie 7 ай бұрын
Awesome, thanks
@codersanInHoodie
@codersanInHoodie 3 ай бұрын
what is stopping java from implementing this?
@fuzuligulmammadli7884
@fuzuligulmammadli7884 2 ай бұрын
Backwards compatibility i guess
@_GhostMiner
@_GhostMiner 2 ай бұрын
Why does your voice sound like it's constantly dying?
@Mr-Sinister
@Mr-Sinister 2 ай бұрын
I mean, I like Rust, but sometimes I don't need these restrictions in my way. I would prefer the freedom of C. Besides, there are analyser tools that can help locate potential memory leaks. The beauty of C is that one can imagine what the assembly code would look like behind the scenes, with Rust's abstractions it would be more difficult. You pay with overcomplexity for just not having to free memory yourself. All you have to do is use tools that help you locate problems in the code where memory leaks could be, OR design your C code that way so you don't have memory leaks (so that you know for sure where all allocations and deallocations are). With Rust you would still have to design your code to comply with borrow checker anyway. Rust could be a language for perfectionists, but you can still be one using other languages.
@dorovich4735
@dorovich4735 2 ай бұрын
based C freedom enjoyer
@Jardynq
@Jardynq 2 ай бұрын
"All you have to do is use tools that help you locate problems" so..... a language built in tool like a borrow checker
@Mr-Sinister
@Mr-Sinister 2 ай бұрын
@@Jardynq when you develop in C, the main "borrow checker" should be in your brain. Good architecture and code design will solve these problems at early stage of development, and perhaps even save you from using tools for too long (depends on the project scale). Rust forced slightly different way of coding becuase of the language design, and this could create a new set of logical problems that you would still need to address. Take Linked List implementation in Rust for example. I don't need this protection that Rust forces, I need full control. I guess Rust is really needed in those cases where programmers can't protect themselves from making mistakes. I really don't like the idea of such fundamental restrictions that force me to write code in some other way, not the way I want it to be written. No language will take away my freedom. Rust can be still used for critical parts when and if I choose it as a tool for the task. But becoming pure Rust evangelist is not going to happen.
@antifa_communist
@antifa_communist 2 ай бұрын
You have control in Rust too. You clearly don't know anything about Rust. You just need to opt out of safety.
@antifa_communist
@antifa_communist 2 ай бұрын
C is better at absolutely nothing. Rust can do all the same things, while preventing you from making mistakes.
@Joe3D
@Joe3D 2 ай бұрын
dude your voice is that on purpose
@jacobpradels
@jacobpradels 2 ай бұрын
@@Joe3D no
@coolandonrs3680
@coolandonrs3680 Жыл бұрын
Now, I’m probably missing something, but why not just… share ownership? When an owner is removed from the stack, it or an intermediary just double checks there are no other owners before unallocating it. Yes, this requires storage to know the other owners, and possibly an intermediary process, but given you could using something like a hash table to store this minimal data compactly and quickly accessible, and the intermediary process (if it exists) would only be executed when needed, instead of constantly. Would this not minimally impact the efficiency of the concept, but remove all the drawbacks of switching ownership and multi-scoped variables? At least to me, this functionality concept of this seems to fundamentally break scope inherited variables in closures, which sounds terribly annoying.
@Mempler
@Mempler Жыл бұрын
This would be referenced counting instead of ownership. Rust also has that with `Rc` but it does use a lot more memory and may even be really dangerous when doing multi threading when releasing both Rcs thats what Arc is for, a thread safe version of Rc with essentially a mutex to change the inner rc. correct me if i'm wrong.
@jacobpradels
@jacobpradels Жыл бұрын
Great question! I really appreciate questions like this and I think it highlights something I forgot to mention in the video which is that one of the big benefits rust provides here is the ability to do this checking at compile time rather than runtime. And this allows for catching various kinds of bugs before code can even be built. The solution you mentioned sounds very similar to reference counting. I’m far from an expert in language design, but there are trade offs when you move in either direction.
@ianakotey
@ianakotey Жыл бұрын
That exists in Rust too.
@coolandonrs3680
@coolandonrs3680 Жыл бұрын
Thanks for the informative answers! I’m not entirely sure why that wouldn’t be the default, but there probably is a good reason. I’ve been meaning to learn rust, if nothing else learning about this more might be a good reason to startx
@AK-vx4dy
@AK-vx4dy Жыл бұрын
You can share immutable refenece easily in Rust, also you can "borrow" someting for a moment, all static at compile time. If you need runtime safe sharing there also many ways but the are explicit in Rust, explicit in function and additional cost.
@Yougottacryforthis
@Yougottacryforthis Ай бұрын
Wow so rust reinvented unique ptr waow 😊
@Valerius123
@Valerius123 3 ай бұрын
Rust did not introduce the concept of ownership. It's just the first performance based compiled language to come out in a long time that *also* facilitates ownership. And what... do you think you get this all for free? What you're sacrificing is the overall design and maintainability of your program since you become burdened by its approach to ownership rather than being able to implement your own.
@antifa_communist
@antifa_communist 2 ай бұрын
Incorrect, there's no burden at all. It makes it a lot easier. You should learn more about Rust before you judge it
@Valerius123
@Valerius123 2 ай бұрын
@@antifa_communist "Someone has a position I disagree with so it must come from a position of ignorance". I'm not even surprised someone who bears the name "antifa_communist" thinks like this. Grow up.
@sergiucimpoi8497
@sergiucimpoi8497 2 ай бұрын
Before posting such a ridiculous claim, you should have checked the RAII. This makes your Rust so cool, to destroy something when goes out of scope. C++ smoked this long time ago. Rust has better implicit move semantics management in compiler. But RAII is C++
@oraz.
@oraz. 3 ай бұрын
I too pray to the god of safety. Even people with the best intentions run into the sea, that's whyI wear a life vest. Only thing I refuse is to debug. Not part of programming for me and I hope I never encounter such a situation.
@1n4f4bl3
@1n4f4bl3 3 ай бұрын
Rust’s strict ownership rules can sometimes lead to inefficient patterns when compared to languages like C, where manual memory management allows for more granular control. For example, Rust may require clones in certain situations to satisfy the borrow checker, which can lead to performance overhead.
@buycraft911miner2
@buycraft911miner2 3 ай бұрын
If you really need a raw pointer, unsafe rust exists. the difference is, you can limit the unsafe code to very reduced sections, and make the api safe externally.
@antifa_communist
@antifa_communist 2 ай бұрын
Incorrect. You can do the same thing in Rust, it's just more explicit.
@Finkelfunk
@Finkelfunk 2 ай бұрын
Actually, you picked a really poor example at the start. The issue is not with programs that just forget to clean up resources and then exit. The kernel keeps track of heap allocations and once the program terminates it just frees that memory right up. This is technically a memory leak, but it has no effect on a modern operating system. While this is not best practice, this is perfectly safe and fine to do. What you should have gone with are applications like Kernel Modules or Daemons that continually run in the background but never use free() to give back memory. Those are a much bigger problem as they constantly call for more and more resources, but never free them. This will, over a long enough period, cause an _actual_ memory leak. And to be completely honest: Rust fanboys WAY over-hype memory leaks. Worst case the Kernel denies the resources and you get an error which crashes the program and frees everything anyway. Rust fanboys really need to stop acting as if memory leaks are a thing that every application needs to care about. In 95% of applications you won't even notice that they occur. Yes, those 5% of applications benefit from it, but that is no reason to rewrite all of the programs in Rust.
@amuerta3041
@amuerta3041 10 ай бұрын
I don't really get the obsession with Rust's ownership model, yes its cool and almost always promises the programmer to handle memory deallocation in the end of the scope, but... combined complexity of other things in the language like enums that can hold values , Heap based types (Rc, Box,Arc,etc.) or Macros make it unbearable to quickly develop things. Problem that nearly everyone point at, of: "bug because of use after free" or "forgot to free() in C, unsafe!!!!" aren't as much of a deal as the unnecessary complexity of doing literally anything in the language. It could've be the case, if there where no debug tools, valrgrind or bounds checking in all of the system programming languages for decades. I doubt that you need majority of the features (even core one) in rust to make "safe software".
@strandingstranger
@strandingstranger 9 ай бұрын
you kinda sound like chris griffin
@KhaledKimboo4
@KhaledKimboo4 8 ай бұрын
what is ti with rust programmers i've never seen similar weird community of a programming language, i've used rust for 2 years along side C/python and Go recently, it is : a simple language + "best practices" enforced by the language anyone can by choice implement those concepts in any other language . for example all languages have mutex, rust enforces mutex wrappers on mutables to avoid lock-ins (you forget to unlock) the same wrapper could be implemented in any language in 10 lines of code only rust ENFORCES IT ON YOU and calls it a feature, get over yourself just learn the concepts and use any language you feel productive using (5% performance increase doesn't matter in 99.99% of your projects) by the way none of rust "best practices" are invented by rust team all are known techniques from 70's and 80's long before they were even born
@RenderingUser
@RenderingUser 3 ай бұрын
"none of these things was invented by rust" Funny how you'd say that when rust is unlike most other popular languages. Sure it existed somewhere in random languages. Rust put it all together and streamlined it.
@QTwoSix
@QTwoSix 2 ай бұрын
Rustroon
@alirezanet
@alirezanet Жыл бұрын
You should claim rust is the best if you can compare it with something like Zig, I believe zig has the best of the two worlds
@pietraderdetective8953
@pietraderdetective8953 8 ай бұрын
Watch Primeagen videos..he often mentions Zig got 80% of Rust memory safety features, but is 80% easier to write compared to Rust.
@RenderingUser
@RenderingUser 3 ай бұрын
Zig is still incomplete
@antifa_communist
@antifa_communist 2 ай бұрын
No. Better than C++ but Rust is still better
@mohaofa1544
@mohaofa1544 Жыл бұрын
Rust Probaganda be like C is Old C++ is Bla bla bla and in the last minute they start talk about Rust and then the vedio end
@Z3rgatul
@Z3rgatul 2 ай бұрын
This all works fine with hello world example. Good luck with implementing something real in Rust
@pyyrr
@pyyrr 2 ай бұрын
true. i still havent seen it actually being used in a real project
@antifa_communist
@antifa_communist 2 ай бұрын
Real things are implemented in Rust. Microsoft, Google and Amazon use it. It's in Android and Linux.
@antifa_communist
@antifa_communist 2 ай бұрын
​@@pyyrr are Linux and Android not real projects?
@Z3rgatul
@Z3rgatul 2 ай бұрын
@@antifa_communist I am not saying Rust is not used anywhere. I am saying when you try to use it on real project it becomes a lot more challenging to write Rust code. Even though the companies you mentioned use Rust, its part must be about 0.001% of all their code.
@DWal32
@DWal32 3 ай бұрын
ah yes, the assignment operator actually _moves_ things! what a well designed language.
@antifa_communist
@antifa_communist 2 ай бұрын
You don't understand what that means at all. Nothing is actually moved. Ownership is moved. Please learn before you make assumptions.
@DWal32
@DWal32 2 ай бұрын
@@antifa_communist perhaps you should think before you start saying even dumber things. obviously nothing is "moved," ownership is just changed in memory. The problem is that the values you would normally get from the original variable are no longer accessible from that variable, and instead appear to "move" to another variable. i.e. the psuedocode "a = [0, 1, 2]; b = a;" would "move" ownership of the array from a to b, resulting in a having no value.
@johnnm3207
@johnnm3207 Жыл бұрын
Zig >>>>>>>>>>
@AK-vx4dy
@AK-vx4dy Жыл бұрын
What Zig ? It is amazing C replacement, but different beast :)
@mppl_yt502
@mppl_yt502 2 ай бұрын
0:35 of a video and already i can say skill issue
@jacobpradels
@jacobpradels 2 ай бұрын
@@mppl_yt502 nice
@fr0xk
@fr0xk 7 күн бұрын
Rust doesn't protect you from memory leaks dude.
@rw_panic0_0
@rw_panic0_0 Жыл бұрын
someone pls explain to him Rust does not protect from memory leaks in the first place..
@peter9477
@peter9477 9 ай бұрын
It actually does. What you mean, I believe, is that it cannot prevent you from deliberately causing a leak (and obviously! given that it includes mem::leak()). But it definitely prevents inadvertent leaks in almost all cases by tracking ownership and dropping where required. That's what is meant, not that it's literally impossible to cause a leak.
@marcossidoruk8033
@marcossidoruk8033 5 ай бұрын
​@@peter9477 Reference cycles with reference counted pointers can produce memory leaks and many times its not trivial when those will happen.
@peter9477
@peter9477 5 ай бұрын
@@marcossidoruk8033 How are you going to make those in Rust without using unsafe code?
@rafagd
@rafagd 3 ай бұрын
It protects you from certain classes of memory leaks. Of course you can still use a Vec or HashMap improperly and have memory bloat, but those are more of logic problems than random footguns. It's not perfect and it was never meant to be.
@Darqonik
@Darqonik 2 ай бұрын
Lol haters saying that rust can leak memory without examples as always 😂
@rogercruz1547
@rogercruz1547 2 ай бұрын
too much vocal fry
@KevinInPhoenix
@KevinInPhoenix 3 ай бұрын
Garbage collection is hard, so Rust pushes memory management issues onto the programmer. While this speeds up execution time, it slows up development time. I would rather devote my mental energies to the problem domain than concern myself with the complexities of memory management.
@RenderingUser
@RenderingUser 3 ай бұрын
Development time is slowed down due to uncertainties that require extra runtime bug fixing. In rust, if it compiles, it works. If you don't want to deal with the complexities of memory management, don't use a compiled language
@KevinInPhoenix
@KevinInPhoenix 3 ай бұрын
@@RenderingUser Golang seems to be a good compromise between compiled and interpreted languages.
@snesmocha
@snesmocha 2 ай бұрын
the fact people still need to sell this language to get people to use it instead of just using it 😆 what a joke
@antifa_communist
@antifa_communist 2 ай бұрын
People do use it though. What do you mean.
@SC-ck8pb
@SC-ck8pb 3 ай бұрын
3 words before the end of every sentence you run out of breath, can you please talk normally? it is disturbing
@flurry301
@flurry301 3 ай бұрын
C better lol
@johnymehlabo
@johnymehlabo 2 ай бұрын
Rust hasn't invented anything, that's already in C++ with smart pointers
@Marksman560
@Marksman560 2 ай бұрын
With garbage collection, every object has ownership, hence better.
@MyWatermelonz
@MyWatermelonz 6 ай бұрын
It is a big claim, going forward seems like python will be the best programming language
@epicmoofish3726
@epicmoofish3726 6 ай бұрын
me waiting for my empty python for loop to finish (its on the 2nd iteration and its been 8 hours)
@playthatsoloboi3705
@playthatsoloboi3705 2 ай бұрын
i love your videos but your voice is annoying
@jacobpradels
@jacobpradels 2 ай бұрын
@@playthatsoloboi3705 you get it
@deadmarshal
@deadmarshal 10 ай бұрын
Rust is a joke!
@Simple_OG
@Simple_OG 8 ай бұрын
You are a joke
@Bilal-l2q
@Bilal-l2q Ай бұрын
why???
@erichstocker8358
@erichstocker8358 4 ай бұрын
No memory management isn't hard. Free the space. Why do you need some fascist language to enforce what decent programmers ought to be doing. Also, memory leaks may or may not be an issue in a program. It is inefficient and not good practice but depending upon the task it may or may not be an issue. Trading simplicity for complexity is not always the best solution.
@antifa_communist
@antifa_communist 2 ай бұрын
There are many reasons why you might not free the space. You might forget for example. You don't understand Rust at all. Comparing it with fascism is laughable.
@zxcaaq
@zxcaaq Жыл бұрын
clickbait
@hahavx512
@hahavx512 5 ай бұрын
Rust re-invents RAII. Wow. So cool. No.
Understanding Ownership in Rust
25:30
Let's Get Rusty
Рет қаралды 277 М.
Rust Functions Are Weird (But Be Glad)
19:52
Logan Smith
Рет қаралды 157 М.
人是不能做到吗?#火影忍者 #家人  #佐助
00:20
火影忍者一家
Рет қаралды 20 МЛН
Chain Game Strong ⛓️
00:21
Anwar Jibawi
Рет қаралды 41 МЛН
This Is How Rust Stops Memory Leaks
5:53
Low Level
Рет қаралды 171 М.
8 deadly mistakes beginner Rust developers make
14:14
Let's Get Rusty
Рет қаралды 180 М.
WHY IS THE HEAP SO SLOW?
17:53
Core Dumped
Рет қаралды 298 М.
Use Arc Instead of Vec
15:21
Logan Smith
Рет қаралды 165 М.
why rust libraries may never exist.
7:26
Low Level
Рет қаралды 294 М.
Ranking Java Features Added from Versions 8 to 21!
27:03
Tales from the jar side
Рет қаралды 12 М.
Rant: Entity systems and the Rust borrow checker ... or something.
1:01:51
Rust Error Handling - Best Practices
21:33
Jeremy Chone
Рет қаралды 28 М.
Jai vs Odin systems programming languages (Non-spicy takes!)
20:10
Context Free
Рет қаралды 83 М.
人是不能做到吗?#火影忍者 #家人  #佐助
00:20
火影忍者一家
Рет қаралды 20 МЛН