I might not have the most experience in the world but I've gone through 5 programming languages that I feel somewhat comfortable in, along with all their ecosystem, communities, documentations, tutorials etc. Just wanted to say you sir are making the best programming learning resources I've seen so far. You are truely gifted, thank you so much for sharing your knowledge. Cheers from Poland.
I didn't realize you wrote Rust for Rustaceans. I preordered a physical copy last month, before finding this channel; I was pretty excited for it to arrive. After finding your exceedingly informative channel, I'm now very very excited for the text version! Thanks for filing this niche.
I just found your channel yesterday as I have started learning rust a few weeks ago. Good thing I found you early, your explanations are very good, I could understand everything perfectly. If I am not sure about something, I just go back to your explanations, and it just clicks. Thank you for making your videos available for us. I haven't watched all your videos yet, but I plan to keep watching until I fully absorb everything you shared.
Great video, since I came from C ++ to Rust, it's just great for me to see videos like this at this quality level! I have a suggestion for a possible future video: Since Rust has no inheritance like many languages like Java / C ++, you could possibly make a video showing how object-oriented solutions are made differently in Rust, that would be interesting
People are asking for "teach me this teach me that", i just wanna know how you learn all these things. how do you read docs?. How long does it take in average to say "ah..i got it".Consider creating a video on learning a new topic u are not familiar with in rust in live stream. Just like teaching a person "how to catch and eat a fish" rather than "how to eat a fish". P.S. Thanks for making these videos, they are great learning material
You learn by doing. Start a project, set a goal, whenever you end up getting stuck, you'll know what question to ask to further your knowledge base. Ask that question, research, accomplish your goal, then move on to the next goal. Rinse and repeat.
You know, everything is in the official rust book wich is on their offical page. You would think someone who wanted to learn such a niche language would take the time to go trough the proper docs.
I love Rust's implementation of closures since not only is it easier to distinguish from functions/function calls, but if you just want to return a value (like in unwrap_or_else), you don't need ()=>{return 0;}, you just need ||0, making it so much more concise.
Rust and the teaching tools around it have finally helped me escape the "writing bad, unflexible scripts" stage of my programming career. Thanks Jon for all your incredible videos! Can't wait to check out your book.
Jon awesome class, its the third time that I'm see again and always learning something new!!! Thank u very much to spend your time with this incredible class
I think a good substitute for "advanced" in things like "advanced topics" is to lean on the layering model of knowledge, where "this knowledge requires having mental frameworks already in place (from having learned previous topics) in order to make sense of it and intuit its use".
7:20 Function items are coercible into function pointers 18:30 FnOnce, FnMut, Fn hierarchy (self can be turned into &mut self and &self, &mut self can be turned into &self) 19:15? A function pointer implements Fn, and therefore also implements FnMut and FnOnce 22:00 Closures which do not capture over their environment are coercible to function pointers (fn type) 28:45 Passing an FnMut into quox (mut in signature) 30:30 So if a closure that implements the FnOnce trait is expected, then FnMut and Fn can be input. If FnMut is expected, then Fn can be input but not FnOnce. (See note at 18:30) 32:00? The compiler can deduce if a closure requires move, but there are edge cases i.e. when dropping a value in the closure 35:20 If move is not specified, the value would be borrowed from the environment's scope and require a lifetime 37:00? Shadowing 42:20 dyn is not Sized, so there's always a reference/exclusive reference to it or Box around it (history on standard library implementation of Fn* for Box) 46:00 The wrapper type (indirection type) needs to allow access to dyn Fn*: &dyn Fn(), &mut dyn FnMut(), Box 47:45 Arc always gives shared access, so Arc still only implements Fn (missing implementation for Arc!) 1:02:30 for syntax to specify lifetimes in Fn* trait 1:05:00? static in async
Jon , thank you so much for resources that you have been sharing for free for the Rust community or anyone interested. Your contents pulled me to Rust and am investigating time to learn it better.
Unfortunately, sending the book to Europe would cost almost like the book itself, but hey, that's what the ebook version is for ;) ! Thanks for all the content, hope buying the book will help you getting even more contents out!
Jon - Thanks so much for this instructive video. Clearly, the rich and challenging concepts you demonstrate in Rust require careful consideration and exploration before use. Closures are still a challenge to fully comprehend, not because you video lacked anything, but simply because the Rust idiom requies one to carefully design the program's call flow. As an aside, would you be willing to share your .vimrc file and the plug-ins you are using?
i have a small doubt. you said Fn implements both Fnmut and Fnonce when we passed closure to the Fn where it needed mutable access there was an error. So what ever is Fn should have Fnmut and Fnonce isnt it ? or did i misunderstood the explanation
50:00 Maybe I'm just dumb, but I can't for the life of me think of the utility of a const fn expression. Since it can be evaluated at compile time couldn't we just replace the const fn with whatever const value it is evaluating to?
Sometimes you can, but that doesn't work for, say, constructing types that are defined outside of your crate (since you can't name their private fields). Sometimes it's also nice to express the computation rather than the final result. As a trivial example, would you rather have a constant with the value 2592000 or one defined as 30*24*60*60?
I am facing an error that has me stumped. higher-ranked lifetime error could not prove `[async block std::marker::send. This is on the tokio::spawn closure. When i try to capture an Arc.
Is the whole point of "as_str()" that, if you didn't call it, the string would be consumed upon calling a method, or does it have more to do with the Slice trait having those methods that you are calling - such as len()?
13000 views - I'd say Rust is picking up some steam. Nice video. I had one question if you don't mind - when calling the closure, why is the parentheses around the variable needed, such as "(f)()" instead of just "f()"
Ah, imagine there's a fn f() {} in the same scope - it wouldn't be clear which to call. (f)() indicates to call the function indicated by the *value* f, not the *name* (technically function item type) f.
Jon, you need to sell some kinda cheat sheet. Rust has too many little "isms". Too hard to remember. But I guess a rust cheat sheet would be whole book, so ... COR says "steal a value from a borrow and replace it with another". Audience looks at each other. That's rust though.
Ah, probably, although I feel like I've been posting it _everywhere_ recently :p It's also pretty easy to find since it should be on most retailers and such. nostarch.com/rust-rustaceans is the one you probably want.
I'd love to get the physical book, but the shipping is nearly as expensive as the book, and that's just not right. It's so unfair how Americans can get something for like $5 in shipping and I have to pay $25-45 for the same thing.
Yeah, the international shipping cost is pretty unfortunate. The good news is that it'll be available at local retailers too eventually (I'm guessing end-of-year, but depends on the distributor), and then it should be much easier to get a hold of!
It's crazy syntax. Its like assambler. Nothing intuitive.... _: fn :: std mem etc... For someone who can program, there are some points what they can see, but for absolutly new programmer it must be demotivation to learn something.
_ is a wildcard same as other languages, it means you can stick everything, :: what is called the "turbofish" means you coerce somehting to what is contained inside the TB in this case an i32, fn is a pointer to a function. Not a crazy syntax at all if you carefully study the doc. Ciao
I might not have the most experience in the world but I've gone through 5 programming languages that I feel somewhat comfortable in, along with all their ecosystem, communities, documentations, tutorials etc. Just wanted to say you sir are making the best programming learning resources I've seen so far. You are truely gifted, thank you so much for sharing your knowledge. Cheers from Poland.
He is my favorite learning resource on RUclips, Jason Turner close second (c++) and Ben Awad third (web)
Zgadzam się. Koleś mega mądry i do tego potrafi wytłumaczyć
I didn't realize you wrote Rust for Rustaceans. I preordered a physical copy last month, before finding this channel; I was pretty excited for it to arrive. After finding your exceedingly informative channel, I'm now very very excited for the text version! Thanks for filing this niche.
Definitely the best Rust content on RUclips 👍
I just found your channel yesterday as I have started learning rust a few weeks ago. Good thing I found you early, your explanations are very good, I could understand everything perfectly. If I am not sure about something, I just go back to your explanations, and it just clicks. Thank you for making your videos available for us. I haven't watched all your videos yet, but I plan to keep watching until I fully absorb everything you shared.
If I ever manage to get a Rust job it will be 90% because of you. I’ve learned so much through your amazing videos and streams!
Great video, since I came from C ++ to Rust, it's just great for me to see videos like this at this quality level! I have a suggestion for a possible future video: Since Rust has no inheritance like many languages like Java / C ++, you could possibly make a video showing how object-oriented solutions are made differently in Rust, that would be interesting
Great suggestion
check out Let's Get Rusty's short video on OOP vs Traits ruclips.net/video/m_phdVlkr6U/видео.html
Great suggestion whenever I see gtk-rs or some rust code I feel examples should be using oops more
my guess would be: structs, traits, and composition.
People are asking for "teach me this teach me that", i just wanna know how you learn all these things. how do you read docs?. How long does it take in average to say "ah..i got it".Consider creating a video on learning a new topic u are not familiar with in rust in live stream. Just like teaching a person "how to catch and eat a fish" rather than "how to eat a fish".
P.S. Thanks for making these videos, they are great learning material
He is a PHD student and have made a database in rust as PHD thesis... so he is very qualified
@@thesuperyou2829 He's not a student anymore, he's already received his PhD and graduated. Now he's working in industry.
You learn by doing. Start a project, set a goal, whenever you end up getting stuck, you'll know what question to ask to further your knowledge base. Ask that question, research, accomplish your goal, then move on to the next goal. Rinse and repeat.
The contents of this channel is by far the best for Rust.
I was JUST the other day wishing you had a video on closures 😂
You know, everything is in the official rust book wich is on their offical page.
You would think someone who wanted to learn such a niche language would take the time to go trough the proper docs.
@@TroenderTass You'd think someone who wanted to troll a community would take the time to come up with a better comment.
I love Rust's implementation of closures since not only is it easier to distinguish from functions/function calls, but if you just want to return a value (like in unwrap_or_else), you don't need ()=>{return 0;}, you just need ||0, making it so much more concise.
Preordered the book. I already know I will get $25 worth of value. I already get that with the RUclips channel!
Like, each of his crust of rust video is worth $25 already, probably $100 if it's taught in a uni
@@cat-.- This is really true.
You're such an amazing teacher
The value of your content will echo through eternity ;)
Rust and the teaching tools around it have finally helped me escape the "writing bad, unflexible scripts" stage of my programming career. Thanks Jon for all your incredible videos! Can't wait to check out your book.
Jon awesome class, its the third time that I'm see again and always learning something new!!! Thank u very much to spend your time with this incredible class
I think a good substitute for "advanced" in things like "advanced topics" is to lean on the layering model of knowledge, where "this knowledge requires having mental frameworks already in place (from having learned previous topics) in order to make sense of it and intuit its use".
7:20 Function items are coercible into function pointers
18:30 FnOnce, FnMut, Fn hierarchy (self can be turned into &mut self and &self, &mut self can be turned into &self)
19:15? A function pointer implements Fn, and therefore also implements FnMut and FnOnce
22:00 Closures which do not capture over their environment are coercible to function pointers (fn type)
28:45 Passing an FnMut into quox (mut in signature)
30:30 So if a closure that implements the FnOnce trait is expected, then FnMut and Fn can be input. If FnMut is expected, then Fn can be input but not FnOnce. (See note at 18:30)
32:00? The compiler can deduce if a closure requires move, but there are edge cases i.e. when dropping a value in the closure
35:20 If move is not specified, the value would be borrowed from the environment's scope and require a lifetime
37:00? Shadowing
42:20 dyn is not Sized, so there's always a reference/exclusive reference to it or Box around it (history on standard library implementation of Fn* for Box)
46:00 The wrapper type (indirection type) needs to allow access to dyn Fn*: &dyn Fn(), &mut dyn FnMut(), Box
47:45 Arc always gives shared access, so Arc still only implements Fn (missing implementation for Arc!)
1:02:30 for syntax to specify lifetimes in Fn* trait
1:05:00? static in async
RUST IS SO INTERESTING AND EXCITING.
I really enjoy your explanations. Well structured, technical and deep explanations! Thanks
Your videos are so good that I sometimes forget to click the Like button. Thanks.
Jon , thank you so much for resources that you have been sharing for free for the Rust community or anyone interested. Your contents pulled me to Rust and am investigating time to learn it better.
one of my faves in the series :)) this and collections, the new one.
Unfortunately, sending the book to Europe would cost almost like the book itself, but hey, that's what the ebook version is for ;) ! Thanks for all the content, hope buying the book will help you getting even more contents out!
How does he get the error message highlight in vim to look like that?
Are you going to implement Arc dyn Fn ?
And can you check for ~const with a trait?
Jon - Thanks so much for this instructive video. Clearly, the rich and challenging concepts you demonstrate in Rust require careful consideration and exploration before use. Closures are still a challenge to fully comprehend, not because you video lacked anything, but simply because the Rust idiom requies one to carefully design the program's call flow. As an aside, would you be willing to share your .vimrc file and the plug-ins you are using?
i have a small doubt.
you said Fn implements both Fnmut and Fnonce when we passed closure to the Fn where it needed mutable access there was an error. So what ever is Fn should have Fnmut and Fnonce isnt it ? or did i misunderstood the explanation
I love your videos. One question, could you do videos more often?
Jon, thank you! This was very helpful.
Do you use neovim LSP or CoC? The inlined error reporting looks really nice…
50:00 Maybe I'm just dumb, but I can't for the life of me think of the utility of a const fn expression. Since it can be evaluated at compile time couldn't we just replace the const fn with whatever const value it is evaluating to?
Sometimes you can, but that doesn't work for, say, constructing types that are defined outside of your crate (since you can't name their private fields). Sometimes it's also nice to express the computation rather than the final result. As a trivial example, would you rather have a constant with the value 2592000 or one defined as 30*24*60*60?
Loving these videos. You are great teacher, keep it up.
Fn, FnOnce, FnMut ,,,, i wanna understand these ... and differences between FnOnce and "move" keyword :(
any resource ?
I am facing an error that has me stumped.
higher-ranked lifetime error could not prove `[async block std::marker::send.
This is on the tokio::spawn closure. When i try to capture an Arc.
I realy enjoy all the explenations and thank you for that great job,
but it's hard for me to figure out with all this extremly abstract exemples.
Just ordered the book for reference, thank you 👍
Is the whole point of "as_str()" that, if you didn't call it, the string would be consumed upon calling a method, or does it have more to do with the Slice trait having those methods that you are calling - such as len()?
Can you please share which vim plugin you are using in the video? Thanks in advance.
There was an audio problem in this stream .
Check obs and your configurations probably changed after the update
Yup, I'm aware - the VoD should have the audio glitches edited out. This isn't normally the case, so I suspect it's related to a recent upgrade.
Are there any updates on _impl Fn for Arc_ and why it hasn't been implemented yet?
twitter.com/jonhoo/status/1447671516041121794?t=aavlfVsytTuCtTzcDQ1dXg&s=19
What firefox css its than one? :)
Hey Jon - question on something unrelated to this video, does any of your long videos show graph implementation?
Thanks for your video. I notice that you move from xmonad :) What is your current tailing windows manager. And is it LeftWM?
What color scheme you using in vim?
11:37: It's 'quux'. But I'm not fond of it myself, so I usually use 'grill' :-).
I use asd qwe zxc fgh rty vbn etc...
What a legend !! 🙇♂️
13000 views - I'd say Rust is picking up some steam. Nice video. I had one question if you don't mind - when calling the closure, why is the parentheses around the variable needed, such as "(f)()" instead of just "f()"
Ah, imagine there's a fn f() {} in the same scope - it wouldn't be clear which to call. (f)() indicates to call the function indicated by the *value* f, not the *name* (technically function item type) f.
@@jonhoo - thanks
I can't just stop to think "How does he know so much?"
I really appreciate this guy ❤️💯
Jon, you need to sell some kinda cheat sheet. Rust has too many little "isms". Too hard to remember. But I guess a rust cheat sheet would be whole book, so ... COR says "steal a value from a borrow and replace it with another". Audience looks at each other. That's rust though.
Would it make sense to put a link to your book in the description?
Ah, probably, although I feel like I've been posting it _everywhere_ recently :p It's also pretty easy to find since it should be on most retailers and such. nostarch.com/rust-rustaceans is the one you probably want.
I've never imagined I'd have such a hate/love relationship with programming language
I know this is off topic but can you share your development setup?! I love the color scheme and all (terminal, vs code, extensions, etc.)
ruclips.net/video/ycMiMDHopNc/видео.html
@@Baremutation amazing. Thanks !!
I'd love to get the physical book, but the shipping is nearly as expensive as the book, and that's just not right. It's so unfair how Americans can get something for like $5 in shipping and I have to pay $25-45 for the same thing.
Yeah, the international shipping cost is pretty unfortunate. The good news is that it'll be available at local retailers too eventually (I'm guessing end-of-year, but depends on the distributor), and then it should be much easier to get a hold of!
@@jonhoo Awesome. I'll keep an eye on the situation!
i didn't know that variables can take fn like javascript lol I didn't even think about using it
thanks for this tutorial
This topic is difficult to understand for me. A little wired feature doesn't exist in other languages
A fan from China, it's really difficult to buy the book
It should become available at local retailers too eventually, and then it should be much easier! I'd guess around the end of the year.
No need to advertise the book I already bought!
Name it function-items
Or fn-items
your screen is too small :)))) with 17 inch monitor ,,, please brooo
It's crazy syntax. Its like assambler. Nothing intuitive....
_:
fn
::
std
mem
etc... For someone who can program, there are some points what they can see, but for absolutly new programmer it must be demotivation to learn something.
_ is a wildcard same as other languages, it means you can stick everything, :: what is called the "turbofish" means you coerce somehting to what is contained inside the TB in this case an i32, fn is a pointer to a function. Not a crazy syntax at all if you carefully study the doc. Ciao
this is not teaching. this is litterally showing off