I really like how Rust doesn't hide complexity from developers behind trade-offs, but rather offers helpful tools to manage complexity as well as sensible defaults.
I had trouble understanding the lifetime annotations system, until this video. The key information I needed was "It does not change the lifetime, but specifies relationships" explanation. Your videos and explanation are clear and easy to follow. Can't wait to see more material. Thanks for going through this and doing all the work.
Funny how people understand things differently, for me that was meaningless, what made sense to me was like, "the compiler needs to know the lifetime of the output" I thought what would it be like to be the borrow checker, and try to figure out the code. These annotations just help the checker figure things out.
That's exactly how I feel writing rust, I want to write code that I know it's wrong but I want to only try it and rust forces me to write good code, it's a love hate relationship 😂
Exactly. We should make a meme like: Me after learning other languages for hours: Wow Let's make a app/game/website. Me after learning Rust for weeks: Why doesn't it compile? What lifetime annotation should I put here? Should I borrow that thing?
I love Rust is forcing me to do the right thing. For example it forces me to handle the options, use the match. But also with using the match statement it forces me to use all posibilities. No null. I love it doesn't have null. (Well in safe space though) but i like how its the default. The defaults are chosen perfectly.
Yeah he complements the book nicely. I find with technical topics that I need a combination of written material, presentations like this and experimentation/practice to get the richest understanding.
I think I already kind of started to realize that it was relationships between the lifetimes, kind of like how a generic doesn't specify a type, but just relationships between types, but you were the first one that made it clear that: 1. The purpose of a lifetime parameter is to explain the lifetime of the output parameter. 2. The smallest lifetime of two inputs with the same lifetime is the one that is used to specify the lifetime of the output. Thanks!
You state at ~13:15 that the lifetime annotation is saying our struct cannot outlive the reference passed into part:first sentence so if we try to use our variable i (agreed) which is an instance of our struct after part:first sentence has gone out of scope we would get an error. However, would note that the annotation means that an instance of ImportantExcerpt cannot outlive the reference it holds in its part:first_sentence field and in that regard the reference in the ImportantExcerpt instance is valid, the owning variable novel does not go out of scope prior to ImportantExcerpt going out of scope.
I was watching this video on the treadmill, and I was enjoying it so much that I actually worked out longer than I was planning without even realizing it until the video was over! Thanks, Bogdan!
at 16:50 if we return announcement from the function , then according to lifetime ellisions it'll be assigned lifetime of self, but don't you think that it might be wrong in some cases
Thank you for explaining lifetimes in a clear and easy to understand manner. I just discovered your series and can’t wait to go through the rest of them! Thank you for the time and effort you have put in to produce these.
this channel has been hugely helpful for me trying to learn rust, especially since I've never heard of a language doing 'borrowing' before. thank you so much!
Hi, Bogdan! I would be really cool to see a video about structs where some fields reference others. More precisely, why it is or is not bad and what are the alternatives.
Thanks for the video series, it's a great addition to the book as it gives a different perspective to a lot of things. One thing I wonder about lifetimes (and I'm learning, so maybe I did not grasp the concept fully yet): It seems to me that assigning the same lifetime 'a to ALL parameters of a function plus all returned parameters is the most restrictive way possible in terms of lifetimes. If an actual use of a function fulfills these "strictest" rule, why is it actually required to write these lifetimes out when defining it? I think, in the longest-string example, no different lifetime declaration than this most restrictive one is even possible - if you try it, a bug occurs where you try to return the "other" parameter. I understand it's probably a complex problem for the compiler, maybe NP-complete, to find the optimal setting, but in cases where the most restrictive remaining one works, why not defaulting to this? One possible explanation (and maybe this is the reason) is when you write a library that exports functions, so the compiler does not know how it is actually used, so lifetime declarations must be exported as well. But this would not apply for private functions. Another way to make it easier would be to add a mode (maybe compiler flag) to automatically fill up lacking lifetimes with the most restrictive setting still possible? Or what also might be interesting (maybe this exists) were external tools, a bit like lint, or optimally included in an IDE, that could auto-suggest lifetimes?
I have been learning Rust from youtube and Rust by Example, and your videos always do the best job when it comes to tricky concepts such as ownership and lifestime. Thanks a lot!
The realization that finally made lifetimes click for me is that the compiler technically doesn’t _need_ them, in the same way that it technically knows what the return type of a function is even if you omit it or annotate it incorrectly. Like explicit return types, lifetimes are for encapsulation. If you keep the function signature the same (including lifetimes), then changing the implementation won’t cause borrow checker/compile errors elsewhere. This is why Rust makes you write lifetimes explicitly outside of the default trivial cases, even though it can tell you how to annotate the current lifetimes in the error message. It is for the same reasons that it forces you to explicitly write the return type, even though it knows what type the function returns: you can ensure it’s actually what you intended; you can refactor safely as long as you don’t modify the function signature, and you don’t need to look up the implementation of a function to know how it can be used.
Your explanations of these topics are concise, complete, detailed and you move right along with them. Outstanding job, all of your videos make these ideas very clear. I tip my hat to you sir! :)
Good explanation of a bunch of things I had a really hard time understanding from the Rust book, when I started learning Rust. This could have spared me a lot of pain 😬
You explain this very succinctly, thank you very much! In my mind, lifetimes are almost intuitive once you think about it. I think I just double guess myself because I expect it to be more complex than it is!
I just wanted to address something that a lot of new rust programmers get wrong, and you also did explain it wrongly. At least it's rarely the case someone wants to do this. I'm going to copy the code you used for the illustration: struct ImportantExcerpt ImportantExcerpt
To clarify, because there are two input lifetimes both &self and announcement:&str are given their own lifetimes.(Rule #1) Because one of the parameters is &self, the return type gets the lifetime of &self. (Rule #3)
I believe this could use an update now that the non-lexical lifetime analyzer has been updated, correct? For example, I do not get an error with rust 1.72.1 on the code sample at 13:00.
and you may ask yourself, why did I struggle with this? Thanks for the explanation. I'd found lifetimes confusing up to now, but the way you demonstrated it, it's quite straightforward!
Superb! really good explanation, got some small pieces that help me to get my head around this lifetime thingy. in the fn longest example, m 11:02 it works if we use string slices instead of Strings, my guess is because these implement the copy trait ? hence the values are moved so the reference to result is valid at the end ?
Awesome! Good explanation of the lifetime concept. I'm looking forward to deal with different lifetimes for variables and convince the compiler that all I'm doing is well planned 🙈 Thank you very much!!
You're a great teacher. Thank you for making this video! Do you know why lifetimes in Rust are rarely given descriptive names? Almost every example I find uses single-letter names like "a".
If the block doesn't end until line 230 but the variable is not used after line 100, does rust deallocate the variable in line 101 or until the block ends? what is the case for the garbage collector?
can you please explain the syntax on line 5 @7.30 ? Don't types follow the colon? Are you assigning a value to the arguments of the call to longest? If so, why isn't an equal symbol used? Are you casting their type instead? And what is the need of using .as_str() in the first place?
I don't understand the first part of the question but the point of calling .as_str() is to get the reference, as this video is about reference lifetimes.
Do you mean the "x: string1.as_str()"? The pattern "var: type = value" only applies to creating variables. The things inside longest(…) are not variables, but passing parameters. When calling functions you can use named parameters, meaning the parameters are not passed in the order they are defined in but by the names they are defined as. To do so you specify the parameter name, a colon and then the value. "x: string1" means "For the parameter named x use the value string1". These grey, smaller text is generated by the IDE/code editor as hints and are not actually there.
Damn, we have a lot of restrictions, but I wish if I get through all these problems I will have a safer, low level, and fast code. Btw, I recently saw in google news that google is rewriting some part of android with Rust, wish more companies start adopting it.
Have a small question about the last example, what is the lifetime of the variable ann which has a generic type T? Why wasn't it explicitly mentioned, like the other input parameters? Would 'ann' also have the same lifetime as x and y, meaning 'a?
Ok, I understand half of this. What I don't understand is e.g. why I need to add /'a/ so many times. Why for instance do we have to add it in angle brackets after the function name? The simple answer to this would be "because Rust requires it", but I'm interested in the longer answer to "why does Rust require it? Is there anything that wouldn't work if in a language Rust2.0 only the input and output arguments had lifetime annotations, but not the function itself?". What I don't understand either is why x and y have the same lifetime annotation, even though we just said x and y can have different lifetimes. And could you show an example where we need more than one lifetime specification, e.g. /'a/ and /'b/? Thanks for these otherwise extremely helpful videos :)
x and y have the same lifetime annotation because the return value's lifetime depends on both of them. It doesn't matter that x and y can have different lifetimes, it's important that the values of both x and y outlive the return value, since the return value can be a pointer to either one. I made a simple modification to the longest() function, to demonstrate how two different lifetimes might be useful: fn weird_longest(x:&'a str, y:&'b str) -> Result { if x.len() > y.len() { Ok(x) } else { Err(y) } } While this also would compile with a single lifetime, it'd mean different things on the call side. Two different lifetimes would allow us to discard one of the actual values, while with the same lifetime we'd have to keep both of them around until the return value goes out of scope. I'm actually not quite sure about "why does Rust require it?". I can't come up with a counter example on the spot, something to think about. One reason might be something like monomorphization, explicitly declaring the lifetimes makes it clear that this is a generic function that might be compiled several times for different calls (what if both parameters have static lifetime?) but I can't quite wrap my head around it.
Great video. Only thing I miss here would be showing how different lifetimes interact with each other inside the fn scope to further illustrate the concept.
Is it possible to make recursive data types like tree nodes using references and lifetimes? Or do you need to use boxes? Boxes are supposed to allocate space on the heap but not all recursive data structures need the heap and should be able to be implemented entirely on the stack.
It seems to be a trend in programming videos lately, and it is VERY distracting. I often find myself pausing the video thinking it’s from elsewhere in my house. I really wish these otherwise talented content creators would ditch the pointless and distracting background audio - it almost ruins what would otherwise be an excellent resource.
You explained really well! and after your explanation I was like is there any single case even where i will need 2 lifetime annotations like 'a and 'b to express my logic! because i think i could do my lifetime annotations for any function or struct just by using 'a only! because if u look deeply for functions it's just annotating all your parameters with 'a which have the possible to be returned from your function and return 'a on the other hand for struct as the struct will become invalid if a single property containing a ref becomes invalid which means we can always pass a single lifetime through the whole struct? because i have tried 5-10 examples and all are working with a single annotation perfectly as expected! so let me know your opinion regarding this!
This was really helpful. So far this seems to be the "ugliest" part of Rust's syntax, though, I guess it's just a direct consequence of having a borrow checker. What's the general consensus on the use of lifetime annotations? Should we be writing code to explicitly avoid needing them whenever possible?
I'd love it if someone who knows could answer this question! I think they become important when you have references in multiple data structures. For example, two Vectors contain a reference to the same value.
It would had been useful to mention that life time could be coerced. That is a reason to use just a' when actually both parameters have different life times.
📝 Get your *FREE Rust cheat sheet* : www.letsgetrusty.com/cheatsheet
I really like how Rust doesn't hide complexity from developers behind trade-offs, but rather offers helpful tools to manage complexity as well as sensible defaults.
This transparancy i like. I dislike magical garbage collectors and other stuff. This is why rust is so great.
There are arguments for both, depending on your application domain. There is never a one size fits all.
biggest draw for me as well
Well put. I'm still wrangling my brain around some of the stuff but slowly it's getting there and with each step you realise how awesome it really is.
I had trouble understanding the lifetime annotations system, until this video. The key information I needed was "It does not change the lifetime, but specifies relationships" explanation.
Your videos and explanation are clear and easy to follow. Can't wait to see more material. Thanks for going through this and doing all the work.
My pleasure!
Came here to say exactly the same thing
Dido
@@NathanHedglin Definitely this in combination with the fact that the borrow checker now uses the passed params to compare the lifetime with result
Funny how people understand things differently, for me that was meaningless, what made sense to me was like, "the compiler needs to know the lifetime of the output"
I thought what would it be like to be the borrow checker, and try to figure out the code.
These annotations just help the checker figure things out.
As a Java/Node/python programmer and learning Rust I never understood lifetimes in Rust, you`re the first to make this `click` in my brain. Thank you.
Frustrated beginner Rust programmer: "Just let me write bad code!!"
The Rust compiler: No. Here's some super helpful tips instead.
That's exactly how I feel writing rust, I want to write code that I know it's wrong but I want to only try it and rust forces me to write good code, it's a love hate relationship 😂
Exactly. We should make a meme like:
Me after learning other languages for hours: Wow Let's make a app/game/website.
Me after learning Rust for weeks: Why doesn't it compile? What lifetime annotation should I put here? Should I borrow that thing?
I love Rust is forcing me to do the right thing. For example it forces me to handle the options, use the match. But also with using the match statement it forces me to use all posibilities. No null. I love it doesn't have null. (Well in safe space though) but i like how its the default. The defaults are chosen perfectly.
@@joelimbergamo639 Having had to debug muuuch bad code I really love this behaviour. Dangling pointers can be a real pita.
🤣🤣🔥
I totally understand lifetime by your video! Thank you so much as a Rust beginner, you made me understand Rust Book 200%!
Yeah he complements the book nicely. I find with technical topics that I need a combination of written material, presentations like this and experimentation/practice to get the richest understanding.
Watching this after going through the chapter helps drive the point home. I'm glad I found this.
I think I already kind of started to realize that it was relationships between the lifetimes, kind of like how a generic doesn't specify a type, but just relationships between types, but you were the first one that made it clear that:
1. The purpose of a lifetime parameter is to explain the lifetime of the output parameter.
2. The smallest lifetime of two inputs with the same lifetime is the one that is used to specify the lifetime of the output.
Thanks!
Perfect explanation. You just gave me that little extra information that I was missing to finally get it into my head. Thx man! 👏🏻
Thanks for taking the time to produce these videos mate. Learning Rust concepts alone isn’t easy. I appreciate it.
Excellent explanation.. been looking for where this concept was simplified with practical examples like this. Nice job
You state at ~13:15 that the lifetime annotation is saying our struct cannot outlive the reference passed into part:first sentence so if we try to use our variable i (agreed) which is an instance of our struct after part:first sentence has gone out of scope we would get an error.
However, would note that the annotation means that an instance of ImportantExcerpt cannot outlive the reference it holds in its part:first_sentence field and in that regard the reference in the ImportantExcerpt instance is valid, the owning variable novel does not go out of scope prior to ImportantExcerpt going out of scope.
I was watching this video on the treadmill, and I was enjoying it so much that I actually worked out longer than I was planning without even realizing it until the video was over! Thanks, Bogdan!
at 16:50 if we return announcement from the function , then according to lifetime ellisions it'll be assigned lifetime of self, but don't you think that it might be wrong in some cases
yes it will be wrong. im sure it will give some "announcement does not live long enough." type of error
Thank you for explaining lifetimes in a clear and easy to understand manner. I just discovered your series and can’t wait to go through the rest of them! Thank you for the time and effort you have put in to produce these.
this channel has been hugely helpful for me trying to learn rust, especially since I've never heard of a language doing 'borrowing' before. thank you so much!
Resolving a longtime mystery in my mind feels so good.
I'd spam the like button if I could.
Hi, Bogdan! I would be really cool to see a video about structs where some fields reference others. More precisely, why it is or is not bad and what are the alternatives.
You cannot do this in Rust.
Hands down, the best explanation of lifetimes I've ever seen
This series is outstanding tbh, thank you for your hard work. Understanding each of Rust's features makes me love it so much more!
Thanks for the video series, it's a great addition to the book as it gives a different perspective to a lot of things. One thing I wonder about lifetimes (and I'm learning, so maybe I did not grasp the concept fully yet): It seems to me that assigning the same lifetime 'a to ALL parameters of a function plus all returned parameters is the most restrictive way possible in terms of lifetimes. If an actual use of a function fulfills these "strictest" rule, why is it actually required to write these lifetimes out when defining it? I think, in the longest-string example, no different lifetime declaration than this most restrictive one is even possible - if you try it, a bug occurs where you try to return the "other" parameter. I understand it's probably a complex problem for the compiler, maybe NP-complete, to find the optimal setting, but in cases where the most restrictive remaining one works, why not defaulting to this? One possible explanation (and maybe this is the reason) is when you write a library that exports functions, so the compiler does not know how it is actually used, so lifetime declarations must be exported as well. But this would not apply for private functions. Another way to make it easier would be to add a mode (maybe compiler flag) to automatically fill up lacking lifetimes with the most restrictive setting still possible? Or what also might be interesting (maybe this exists) were external tools, a bit like lint, or optimally included in an IDE, that could auto-suggest lifetimes?
Bogdan, this video is even clear for me as a code illiterate! Thank you for this and PLEASEEEE keep your lectures this minimal! Cheers!
Thank you for such a comprehensive lifetimes lesson. The learnings from this video will last a lifetime.
This video was so helpful! Been struggling to understand this concept. Thank you!
I have been learning Rust from youtube and Rust by Example, and your videos always do the best job when it comes to tricky concepts such as ownership and lifestime. Thanks a lot!
THIS IS BY FAR THE BEST EXPLANATION. Keep it up man
wow, I saw these 'a-ticks and couldnt find a good/easy explanation for it. You just explained it so easy and perfect. Thanks!!
This is the best youtube video I have ever watched.
This channel is a blessing!
The realization that finally made lifetimes click for me is that the compiler technically doesn’t _need_ them, in the same way that it technically knows what the return type of a function is even if you omit it or annotate it incorrectly. Like explicit return types, lifetimes are for encapsulation. If you keep the function signature the same (including lifetimes), then changing the implementation won’t cause borrow checker/compile errors elsewhere. This is why Rust makes you write lifetimes explicitly outside of the default trivial cases, even though it can tell you how to annotate the current lifetimes in the error message. It is for the same reasons that it forces you to explicitly write the return type, even though it knows what type the function returns: you can ensure it’s actually what you intended; you can refactor safely as long as you don’t modify the function signature, and you don’t need to look up the implementation of a function to know how it can be used.
Your explanations of these topics are concise, complete, detailed and you move right along with them. Outstanding job, all of your videos make these ideas very clear. I tip my hat to you sir! :)
Your explanation is super clear! I know lifetime now! Thank you
your videos are just so incredible man, extremely grateful for these beautifully articulated insights you put out
Just let me live life dangerously
Rust Compiler: Nope! Not on my watch ⌚ safety first 🎈
Then do C or assembler.
Good explanation of a bunch of things I had a really hard time understanding from the Rust book, when I started learning Rust. This could have spared me a lot of pain 😬
You know what? This is currently the best video resource to learn Rust. Thank you Bogdan.
Thank you so much, this is so well explained it finally clicked for me :)
Best lifetime explanation on youtube
You explain this very succinctly, thank you very much! In my mind, lifetimes are almost intuitive once you think about it. I think I just double guess myself because I expect it to be more complex than it is!
Awesome! These examples are very clear for rust lifetime.
I rarely comment on videos, but you did a great job with this. Thanks for sharing!
I just wanted to address something that a lot of new rust programmers get wrong, and you also did explain it wrongly. At least it's rarely the case someone wants to do this.
I'm going to copy the code you used for the illustration:
struct ImportantExcerpt ImportantExcerpt
Hey Alexander, thank you for the correction and taking the time to write this out.
To clarify, because there are two input lifetimes both &self and announcement:&str are given their own lifetimes.(Rule #1) Because one of the parameters is &self, the return type gets the lifetime of &self. (Rule #3)
Thank you so much! This video and the others in this playlist really helps me understand Rust better! ❤
I believe this could use an update now that the non-lexical lifetime analyzer has been updated, correct? For example, I do not get an error with rust 1.72.1 on the code sample at 13:00.
and you may ask yourself, why did I struggle with this?
Thanks for the explanation. I'd found lifetimes confusing up to now, but the way you demonstrated it, it's quite straightforward!
Superb! really good explanation, got some small pieces that help me to get my head around this lifetime thingy.
in the fn longest example, m 11:02 it works if we use string slices instead of Strings, my guess is because these implement the copy trait ? hence the values are moved so the reference to result is valid at the end ?
Great video!, not even ChatGPT was able to explain it this well.
Lifetimes are clear now! Thank's a lot Bogdan
Outstanding quality. Thank you so much for your labor!
Why so less comments? This channel deserves far more attention than this... Sadness
These videos have been fantastic, thank you
Awesome! Good explanation of the lifetime concept. I'm looking forward to deal with different lifetimes for variables and convince the compiler that all I'm doing is well planned 🙈 Thank you very much!!
9:28 lifetime for string literal will be considered(as we are passing string2,as_str(), and it's lifetime is static, then why there is error
You're a great teacher. Thank you for making this video! Do you know why lifetimes in Rust are rarely given descriptive names? Almost every example I find uses single-letter names like "a".
this is a nice little tutorial with so much value. Thanks!
If the block doesn't end until line 230 but the variable is not used after line 100, does rust deallocate the variable in line 101 or until the block ends?
what is the case for the garbage collector?
Your videos are amazing! Thank you so much ❤️
Very clear explanation! Thank you!
So thorough and interesting! Thanks!
Dude great explanation, I finally got the concept!
can you please explain the syntax on line 5 @7.30 ? Don't types follow the colon? Are you assigning a value to the arguments of the call to longest? If so, why isn't an equal symbol used? Are you casting their type instead? And what is the need of using .as_str() in the first place?
I don't understand the first part of the question but the point of calling .as_str() is to get the reference, as this video is about reference lifetimes.
Do you mean the "x: string1.as_str()"? The pattern "var: type = value" only applies to creating variables. The things inside longest(…) are not variables, but passing parameters.
When calling functions you can use named parameters, meaning the parameters are not passed in the order they are defined in but by the names they are defined as. To do so you specify the parameter name, a colon and then the value. "x: string1" means "For the parameter named x use the value string1".
These grey, smaller text is generated by the IDE/code editor as hints and are not actually there.
Damn, we have a lot of restrictions, but I wish if I get through all these problems I will have a safer, low level, and fast code.
Btw, I recently saw in google news that google is rewriting some part of android with Rust, wish more companies start adopting it.
It's good to catch the wave early :)
Also the new modules in Linux Kernel may be written in Rust and that would be big!
Again, another great episode.
Thanks for such a neat explanation. Just a request the audio is little low
Great video, thanks for the content!
You explain very well some difficult notions.
Very well explained, thank you!
Great video, help me understand the lifetime annotation!
Hi, can you make series on poem framework of rust? Lack of resource availability is major concern and first obstacle to get started with it. Thanks :)
Have a small question about the last example, what is the lifetime of the variable ann which has a generic type T? Why wasn't it explicitly mentioned, like the other input parameters? Would 'ann' also have the same lifetime as x and y, meaning 'a?
AWESOME EXPLANATION.!! thANKS SO MUCH!
This was amazingly helpful!
Super, this video is enough to understand lifetime, thanks a lot ❤️❤️
Clear as day. Thank you!
This is great explanation. Love it. Thanks.
very nice explanation. Very helpful.
Chap 10 is a kick to the nuts.
Thank you very much.. Explained very nicely..
Can you do a day event?
Great video and examples! Thank you!
Ok, I understand half of this. What I don't understand is e.g. why I need to add /'a/ so many times. Why for instance do we have to add it in angle brackets after the function name? The simple answer to this would be "because Rust requires it", but I'm interested in the longer answer to "why does Rust require it? Is there anything that wouldn't work if in a language Rust2.0 only the input and output arguments had lifetime annotations, but not the function itself?". What I don't understand either is why x and y have the same lifetime annotation, even though we just said x and y can have different lifetimes. And could you show an example where we need more than one lifetime specification, e.g. /'a/ and /'b/? Thanks for these otherwise extremely helpful videos :)
hopefully someday rust just use AI to generate this lifetime annotation :D
x and y have the same lifetime annotation because the return value's lifetime depends on both of them. It doesn't matter that x and y can have different lifetimes, it's important that the values of both x and y outlive the return value, since the return value can be a pointer to either one.
I made a simple modification to the longest() function, to demonstrate how two different lifetimes might be useful:
fn weird_longest(x:&'a str, y:&'b str) -> Result {
if x.len() > y.len() {
Ok(x)
}
else {
Err(y)
}
}
While this also would compile with a single lifetime, it'd mean different things on the call side. Two different lifetimes would allow us to discard one of the actual values, while with the same lifetime we'd have to keep both of them around until the return value goes out of scope.
I'm actually not quite sure about "why does Rust require it?". I can't come up with a counter example on the spot, something to think about. One reason might be something like monomorphization, explicitly declaring the lifetimes makes it clear that this is a generic function that might be compiled several times for different calls (what if both parameters have static lifetime?) but I can't quite wrap my head around it.
Great video. Only thing I miss here would be showing how different lifetimes interact with each other inside the fn scope to further illustrate the concept.
I don't know why but rust is giving me some feeling of completion when binary is complete and running as expected.
Is it possible to make recursive data types like tree nodes using references and lifetimes? Or do you need to use boxes? Boxes are supposed to allocate space on the heap but not all recursive data structures need the heap and should be able to be implemented entirely on the stack.
yoo at 13:05 is ishmael a mgs v reference?
Thank you for your tutorial. As a small piece of feedback for future videos, the faint music in the background was slightly distracting.
It seems to be a trend in programming videos lately, and it is VERY distracting. I often find myself pausing the video thinking it’s from elsewhere in my house. I really wish these otherwise talented content creators would ditch the pointless and distracting background audio - it almost ruins what would otherwise be an excellent resource.
Very nicely done. Thank you 🙏
Great video and explanation, thanks
I loved to know you like The Wheel of Time as well :D
very good man, your videos is easy for beginer like me.❤👍
You explained really well! and after your explanation I was like is there any single case even where i will need 2 lifetime annotations like 'a and 'b to express my logic! because i think i could do my lifetime annotations for any function or struct just by using 'a only!
because if u look deeply for functions it's just annotating all your parameters with 'a which have the possible to be returned from your function and return 'a on the other hand for struct as the struct will become invalid if a single property containing a ref becomes invalid which means we can always pass a single lifetime through the whole struct?
because i have tried 5-10 examples and all are working with a single annotation perfectly as expected! so let me know your opinion regarding this!
This was really helpful. So far this seems to be the "ugliest" part of Rust's syntax, though, I guess it's just a direct consequence of having a borrow checker.
What's the general consensus on the use of lifetime annotations? Should we be writing code to explicitly avoid needing them whenever possible?
I'd love it if someone who knows could answer this question! I think they become important when you have references in multiple data structures. For example, two Vectors contain a reference to the same value.
What tends to happen with languages is that they simplify the syntax over time. Though in the meantime they add more concepts with more syntax. Lol.
Does this still apply, or are compilers more advanced now that we don't need to use generic lifetime annotations anymore?
Very nice explanination!!!!
It would had been useful to mention that life time could be coerced. That is a reason to use just a' when actually both parameters have different life times.
Lifetimes being relational is a revelation.
So when would you use mixed lifetimes?
Thanks for the great content
GREAT video. thank you so much.
намного понятнее чем в книжках. Спасибо)
Thank you : )
Thanks again
Thanks a lot
Thank you for explaining it so well 🙏