Rust Collections Explained

แชร์
ฝัง
  • เผยแพร่เมื่อ 24 ม.ค. 2025

ความคิดเห็น • 74

  • @codetothemoon
    @codetothemoon  2 หลายเดือนก่อน +4

    👉 To try everything Brilliant has to offer for free for a full 30 days, visit brilliant.org/CodetotheMoon/ You’ll also get 20% off an annual premium subscription. They have courses on LLMs and Quantum Computing!

    • @CrazyLuke11
      @CrazyLuke11 2 หลายเดือนก่อน +1

      You little cheater! You implemented not listed a day before uploading and added the trait first comment before we even had a chance

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      @@CrazyLuke11 haha guilty as charged!

  • @flippert0
    @flippert0 2 หลายเดือนก่อน +43

    I strongly disagree socks and coal are "junk". These items keep you warm in winter. Can't do that with diamonds and emeralds (unless you buy socks and coal with them).

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +5

      Touché, good point. My implicit frame of reference was an rpg-like video game, I should have made this clear 😎

  • @Cm0nd00d
    @Cm0nd00d 2 หลายเดือนก่อน +40

    BIG YES to this kind of Rust knowledge. It bridges the gap for JS / Python devs nicely

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +2

      Nice, glad it resonated with you!

    • @Cm0nd00d
      @Cm0nd00d 2 หลายเดือนก่อน +2

      Other things I think will really translate for a TS dev to Rust:
      1. build express server & compare to rust tokio
      2. read csv, parse, run aggregations, write file (compare)
      3. small cli tic-tac-toe game showing limitations of TS types & strength of Rust Traits
      4. Server in-memory operations showing how GC overhead for TS can be problematic at scale, and how Rust automagically removes variables when out of scope. Example usage, aggregator API. Input request is some collection, server queries 4 other APIs, aggregates data and returns collection

  • @NekoApril
    @NekoApril 2 หลายเดือนก่อน +13

    Just as a tip, it might be a good idea to disable code ligatures for the code snippets, at least for videos covering fairly fundamental parts of a language. It might not be hard for people who aren't used to it to figure them out, but it is a small barrier to reading them

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +1

      Thanks for the feedback, this is something I hadn’t considered!

  • @ryanswatson
    @ryanswatson 2 หลายเดือนก่อน +11

    The quality of this video is awesome! Please please make more videos like this, the length and content covered is just right.
    While there are quality videos out there, they end up being very long and unfocused leading to videos closer to an hour long....

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +2

      Thank you, really happy it resonated with you!

  • @MichaelKefeder
    @MichaelKefeder 2 หลายเดือนก่อน +2

    at about 8:51 the the entry(...).or_insert_with(Vec::new) can be rewritten as entry(...).or_default() which clippy will helpfully tell you to do too :) This works because the Default impl of Vec gives you an empty vector.

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      ahh great point! that would simplify things a bit!

  • @leemack4562
    @leemack4562 2 หลายเดือนก่อน +3

    more of this content please, break down of all the most commonly used rust patterns :)

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      Thanks, really happy you liked it!
      I love making this type of content, but I'm not sure how much of it I'll be able to make. People are much less likely to click on things like this, which means the algorithm relegates the video to a state where it isn't really recommending it to many people. And the effect is not linear - it is exponential.
      To paint a picture of the magnitude of this phenomenon - consider two videos. Video A gets clicked on by 8% of the people to whom it is recommended. Video B gets clicked on by 4% of the people to whom it is recommended. Common wisdom says that Video B would be viewed about half as many times as video A, *but that's not what happens*.
      The TH-cam algorithm picks up on this and will recommend video B to viewers far less frequently than video A, due to its much lower "clickthrough rate". In my experience, with the above numbers (Disregarding average view duration, likes, comments etc, which matter but not as much as clickthrough rate), *video B will get recommended about 1/10th as much as video A*. Which means video B will get roughly 5% as many views as video A. Yeah, wow.
      This seems to be true even if other metrics of video B like average view duration, likes, etc, are superior to those of video A.
      Many consider view count to be a superficial metric, but for those of us making a living from TH-cam, the situation with video B can be a devastating show stopper.
      So tl,dr - it is really hard to make content that will get clicked on less frequently than "normal", even if it is only slightly less. Even if you know it will be very helpful and appreciated by a specific group of folks.
      To be fair, if I were TH-cam I would still design the algorithm exactly how it is - placing a high value on clickthrough rate. If there is a video that viewers are not clicking on, why would we waste valuable screen space in viewer recommendations for that video? TH-cam is funded by advertisers. The longer viewers spend on the platform, the more sustainable the business is. Recommending videos that viewers are less likely to click on will invariably lead to viewers spending less time on the platform, leading to lost revenue.
      I highlight this phenomenon because I think it is something the average viewer is probably not aware of. I do it to provide context, not because I am complaining or because I want to lobby for some change to the algorithm. I actually think the algorithm is fantastic. It's just a harsh reality that makes certain types of content less feasible to create.
      Sorry for the long winded response 😎 I'm probably going to post this on Twitter as well.

    • @tlabu1
      @tlabu1 2 หลายเดือนก่อน

      @@codetothemoon I see this as very strong arguments of how the business model of TH-cam opposes the interests of many people. Admittedly not the majority of people, otherwise these worse rated videos would not have a lower rating than better performing videos. But still people like all of the commenters of this video, who enjoyed it and would like to see more of its kind. Therefore I do complain that the algorithm stands in the way of success for niche videos. I understand your reasoning why the algorithm makes sense for a business, but that does not make it good for the individual viewer.

  • @sergeykuznetsov7688
    @sergeykuznetsov7688 2 หลายเดือนก่อน +5

    Thanks! Really good explanation of collections and iterators!

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +1

      Glad you enjoyed it!

  • @AMusset
    @AMusset 2 หลายเดือนก่อน +1

    Thank you SO MUCH for this video! It finally cleared up the confusion about all this iterator stuff!

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      nice! really happy you got someting out of it!

  • @sususu9
    @sususu9 2 หลายเดือนก่อน +1

    I love this channel
    Taught me so much stuff about rust.
    I always recommend it to other people who learn rust
    Thank you so much

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      awesome, really happy you got something out of it! and thanks for the kind words!

  • @theycallmesloth
    @theycallmesloth 2 หลายเดือนก่อน +1

    My favourite rust feature is exactly this.
    The type system and other features that accomodate it.

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      Agree, the Rust type system is amazing 🤩

  • @taquanminhlong
    @taquanminhlong 2 หลายเดือนก่อน +5

    4:01 I don't think you should use clone there 😂

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +3

      Good catch :) I had all the examples in one program when I was writing them, so I was using clone everywhere. Intended to remove them all for the video but this one slipped through the cracks

  • @christerpherhunter930
    @christerpherhunter930 2 หลายเดือนก่อน +1

    i watched this video while on my coffee rush. I am intimately familiar with the topics you covered in this video. Thank you so much for connecting to me on a deep level!

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      nice, really glad you liked it despite already knowing much of the content!

  • @sanjsahayam5271
    @sanjsahayam5271 2 หลายเดือนก่อน +1

    Very nice explanations of some basic concepts that trips people up. More of this type of content please!

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      thanks for the feedback, will do!

  • @pancakedrivet
    @pancakedrivet 2 หลายเดือนก่อน +1

    Super informative video, the only bit that I wasn't clear on was why the Result would stop iterating on the first error it encountered? It sort of makes sense from context but I don't know where that leaves things like the resulting vec or if you can no longer use the collection (as it's been consumed) and you can't access the elements as you only have the Err variant back?
    (I've been much more likely to use the Vec type so understanding the "rusty" way to do the same thing properly would be awesome!

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      Thanks for the feedback! You're right - In this situation there wouldn't be a resulting vec - the receiver would be assigned a Result that is of the Err variant. As you point out, the original collection would be consumed and no longer usable.

  • @Hellbending
    @Hellbending 2 หลายเดือนก่อน +1

    More of these please B0ss 🤣🤣
    I’d love to see a sectioned series covering all the traits in the std lib (and maybe some of the extension crates traits that are super popular like itertools)

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +1

      nice, glad it resonated with you! and great idea!

    • @Hellbending
      @Hellbending 2 หลายเดือนก่อน

      @@codetothemoon some positive feedback to understand the viewer base side of things- I enjoy seeing your videos pop up and love watching them. A lot of the time I tend to be unsure of what exactly you’ll be covering though (‘direction’ if you will?) I think something like this may help give that solidified feeling that there’s a common audience goal, just some ‘food for thought’ type stuff ig
      Keep on keepin’ on brother 🤙❤️❤️

  • @MyopicSquirrel
    @MyopicSquirrel หลายเดือนก่อน +1

    The difference between into_iter and iter in terms of borrowing is not something I’d ever seen articulated. That’s why all my advent of code solutions have twelfth order references!

    • @codetothemoon
      @codetothemoon  หลายเดือนก่อน

      hah nice glad you got something out of the video!

  • @Mr.BinarySniper
    @Mr.BinarySniper 2 หลายเดือนก่อน +1

    fold is similar to array.reduce method in javascript.

    • @fred.flintstone4099
      @fred.flintstone4099 2 หลายเดือนก่อน +1

      In C# you have the Aggregate method which I believe is similar.

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      I looked into this and you're right! it seems like reduce can mean something a bit different in each ecosystem - for example in Rust it does not allow you to specify an initial accumulator value, and the type of the accumulator must be the same as that of the input elements. But the javascript implementation is more like Rust's fold...

  • @artxiom
    @artxiom 2 หลายเดือนก่อน

    Great video!
    One thing is magical but quite confusing though: you have a Result but in map() you only return an Ok(String) not an Ok(Vec).
    I tried it and was actually surprised that it works.
    How does Result FromIterator "merge" these into the resulting vector?

    • @codetothemoon
      @codetothemoon  หลายเดือนก่อน +1

      thanks, glad you got something out of it! Returning Ok(String) from the map function causes the resulting type to be an Iterator of Result. Result's FromIterator knows we want a Vec because of the type of its Ok variant.

  • @henrymaddocks984
    @henrymaddocks984 2 หลายเดือนก่อน +1

    I did not know about or_insert_with. That's going straight to the pool room.

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      Nice, glad you got something from the video!!

  • @jakubbb
    @jakubbb 2 หลายเดือนก่อน +2

    thank you

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +1

      Glad you liked it!

  • @omarbarra3456
    @omarbarra3456 2 หลายเดือนก่อน +2

    Cool, Rust is powerful thanks

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      Indeed, thx for watching!

  • @benspencer1163
    @benspencer1163 2 หลายเดือนก่อน +1

    thanks a lot for the good work, the beard is awesome 😎 sir

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      thanks for watching, and thank you!

  • @jsf-z3u
    @jsf-z3u 2 หลายเดือนก่อน +2

    Please more videos like this 🙏

  • @antoniong4380
    @antoniong4380 2 หลายเดือนก่อน +1

    What did you use to animate these code snippets?

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน

      Animotion, created by the fellow who runs the “Joy of Code” channel! Fantastic tool.

  • @azthecx
    @azthecx 2 หลายเดือนก่อน

    In rust functional operations on collections are not as user friendly as they could be.
    From a user point of view the .iter() and .collect() add unnecessary fluff.
    If you're operating on a vector, exposing map directly on vector is useful, and its not that far from how its already used by the for loop.

  • @devsimples
    @devsimples 2 หลายเดือนก่อน +1

    Liked the video just for the thumbnail

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +1

      Hah thank you!

  • @deezydoezeet
    @deezydoezeet 2 หลายเดือนก่อน +1

    Noice!

  • @snk-js
    @snk-js 2 หลายเดือนก่อน +2

    can~t still understand, into~thing

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +2

      If you can tell me what part you’re stuck on maybe I can clarify a bit!

    • @antoniong4380
      @antoniong4380 2 หลายเดือนก่อน

      Going into details: ".into()" is from a Trait Implementation, and used to explicitly convert a data type into another if it supports the conversion. Like for example, converting an i8 (Might commonly be refered as Short type in other languages) '.into()' i32 (Might be commonly be refered as int in other languages).
      Here in the video, `"Socks"` are actually a `&str`, which could be considered as a Wide-pointer that holds the memory address to some data plus the length of the data (i. E. How many chars can you safely read. It's kind of like Java' s Arrays, which you can find the array's length by reading the 'length' attribute)
      "&str" are different from "String" because the first is a "wide-pointer" that holds some memory addres + the length, whereas the second is dynamic sized array (Vectors).
      The String (which is a vector under the hood) would additionally hold the capacity, so you can know how many more chars/bytes can you push into the allocation, before you need to re-allocate the string in the heap to get more writing space.
      Short form:
      `String` can be gotten from a "&str", which is where CodeToTheMoon used it the most, and because he was storing Strings, and not & str's, he needed to call ".into()" because Rust doesn't do implicit conversions

  • @_ethqnol_
    @_ethqnol_ 2 หลายเดือนก่อน +2

    Second 🎉

  • @CrazyLuke11
    @CrazyLuke11 2 หลายเดือนก่อน +2

    Third! yay

  • @Khl8122
    @Khl8122 2 หลายเดือนก่อน +1

    Longest 12 minutes video. To fully understand, watch/listen multiple times.

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +1

      Thanks for the feedback. Would a slower pace have been better?

    • @Khl8122
      @Khl8122 2 หลายเดือนก่อน +2

      @ No, the pace and the delivery are good. The topic is not an easy one.

  • @flatmapper
    @flatmapper 2 หลายเดือนก่อน +4

    I don't like Rust just because of ceremony of writing borrowing, ownership fluff.

    • @codetothemoon
      @codetothemoon  2 หลายเดือนก่อน +4

      Understandable!

    • @fred.flintstone4099
      @fred.flintstone4099 2 หลายเดือนก่อน +7

      This is because Rust is a low-level language so it doesn't have any garbage collector, so you shouldn't compare Rust to high-level languages such as C#, Java, JavaScript or Python, you should compare it to other low-level languages such as C, C++, D and Zig. When you compare Rust to other low-level languages you will see why the borrowing and ownership stuff is amazing.

    • @aryangurung30
      @aryangurung30 2 หลายเดือนก่อน +1

      Weak