File:Crust of Rust- Channels.webm

Summary

Description
English: In this (fifth) Crust of Rust video, we cover multi-produce/single-consumer (mpsc) channels, by re-implementing some of the std::sync::mpsc types from the standard library. As part of that, we cover what channels are used for, how they work at a high level, different common channel variants, and common channel implementations. In the process, we go over some common Rust concurrency primitives like Mutex and Condvar.

This is a rich topic, and I highly recommend you go and try to read the crossbeam-channel or flume source code if you're hungry for more! Please also leave questions here or on Discord if you're confused, and I'll try to help explain what's going on.

You can find the final code at https://gist.github.com/jonhoo/935060885d0d832d463fda3c89e8259d and the Discord at https://discord.gg/RJdqQ9n

0:00:00 Introduction 0:08:20 Initial structure 0:14:27 Structure Q&A 0:19:20 send and recv 0:29:03 send/recv Q&A 0:34:36 Does it work? 0:40:28 Zero senders 0:46:27 Q&A 0:50:53 Why does it hang? 0:53:08 Implementation Q&A 0:58:37 Synchronous channels 1:05:55 Batch recv optimization 1:13:23 Channel flavors 1:18:48 Flavor Q&A 1:22:32 Other implementations 1:32:24 Future-aware channels 1:36:27 Where next? 1:38:24 Channels Q&A

You can find crossbeam-channel at https://github.com/crossbeam-rs/crossbeam/tree/master/crossbeam-channel, and flume at https://github.com/zesterer/flume/.

You can watch the live version with comments at https://www.youtube.com/watch?v=JvBUKsFIUKw
Date
Source YouTube: Crust of Rust: Channels – View/save archived versions on archive.org and archive.todayCategory:Media from YouTube
Author Jon Gjengset

Licensing

This video, screenshot or audio excerpt was originally uploaded on YouTube under a CC BY license.
Their website states: "YouTube allows users to mark their videos with a Creative Commons CC BY license."
To the uploader: You must provide a link (URL) to the original file and the authorship information if available.
w:en:Creative Commons
attribution
This file is licensed under the Creative Commons Attribution 3.0 Unported license.
Attribution:
Jon Gjengset
You are free:
  • to share – to copy, distribute and transmit the work
  • to remix – to adapt the work
Under the following conditions:
  • attribution – You must give appropriate credit, provide a link to the license, and indicate if changes were made. You may do so in any reasonable manner, but not in any way that suggests the licensor endorses you or your use.
Category:CC-BY-3.0#Crust%20of%20Rust-%20Channels.webm
Category:Media from YouTube#Crust%20of%20Rust-%20Channels.webm
This file, which was originally posted to an external website, has not yet been reviewed by an administrator or reviewer to confirm that the above license is valid. See Category:License review needed for further instructions.
Category:License review needed (video)#153341829 Category:Uploaded with video2commons Category:Videos of Rust (programming language)
Category:CC-BY-3.0 Category:License review needed (video) Category:Media from YouTube Category:Uploaded with video2commons Category:Videos of Rust (programming language)