Introduction to C++ Coroutines Through a Thread Scheduling Demonstration - Dian-Lun Lin CppNow 2023

  Рет қаралды 11,110

CppNow

CppNow

Күн бұрын

Пікірлер: 12
@simonfarre4907
@simonfarre4907 Жыл бұрын
I loved this talk. He uses simple ideas and examples of "here is what compilers do kind of". Instead of overly unnecessary theoretical nomenclature - that often tend to be wrong or just not suitable. Loved the talk.
@rolandinnamorato1953
@rolandinnamorato1953 9 ай бұрын
Nice presentation and style
@theintjengineer
@theintjengineer Жыл бұрын
Huh, a lot of Coroutines _Experts_ in this talk. They could all get together and implement a Coroutines Library or help Eric Niebler with the integration into Senders and Receivers👌🏽 Anyways... Good job, Dian-Lun👏🏽
@LesleyLai
@LesleyLai Жыл бұрын
Awesome talk! That "compiler's view" comparison really clarifies things to me
@wolpumba4099
@wolpumba4099 5 ай бұрын
*Summary* *What are C++ Coroutines? (**0:41**)* * Functions that can suspend themselves and resume later, allowing for asynchronous, non-blocking code. * Similar to functions in Go and Python. * Simplify asynchronous programming by allowing code to appear concurrent within a single thread. * Can lead to improved performance and more readable code. *Why use C++ Coroutines? (**2:47**)* * Enable efficient multitasking by overlapping tasks, like CPU and GPU operations. * Provide greater expressiveness compared to splitting tasks into multiple functions and managing synchronization. *Four Components of C++ Coroutines: (**17:18**)* * *Coroutine: (**17:38**)* The function itself, defined using keywords like `co_await`, `co_yield`, or `co_return`. * *Promise: (**17:24**)* Controls the coroutine's behavior, including suspension points, exception handling, and return object creation. * *Awaitable: (**29:26**)* Determines the behavior at specific suspension points, allowing for customization beyond simple suspension. * *Coroutine Handle: (**36:03**)* A pointer-like object used to access the promise and resume the coroutine. *Scheduler Implementations Demonstrated: (**37:38**)* * *Single-Threaded Scheduler: (**37:38**)* Simple scheduler demonstrating basic coroutine execution. * *Multi-Threaded Scheduler: (**53:21**)* Utilizes multiple threads to execute coroutines concurrently, showcasing task distribution and synchronization. * *CPU-GPU Scheduler: (**59:44**)* Demonstrates efficient task scheduling by overlapping CPU and GPU operations using coroutines. *Performance Evaluation: (**1:06:21**)* * Benchmarking revealed a performance improvement when using coroutines for CPU-GPU workloads, especially with a larger number of tasks. * The overhead of using coroutines was minimal compared to the performance gains from efficient task overlapping. *Key Takeaways:* * C++ coroutines provide a powerful mechanism for writing asynchronous code. * Coroutines are particularly beneficial for heterogeneous computing environments with tasks that can be overlapped. * Understanding the four components of C++ coroutines is crucial for effective implementation and customization. * While powerful, effectively utilizing coroutines requires careful consideration of asynchronous API design and potential overhead. i summarized the transcript with gemini 1.5 pro
@videofountain
@videofountain 10 ай бұрын
Thanks. Dian-Lun Lin can be heard with reasonable audio. The audience members have inferior audio. This degrades the listening experience. I am a little surprised that some moderator did not ask the audience to speak into a microphone. Can someone from CppNow make a comment on the audio quality? Lin himself can be seen using extra nano effort to hear the audience.
@stevepa3416
@stevepa3416 Жыл бұрын
13:30 my boi Fedor
@bagel7860
@bagel7860 10 ай бұрын
After hearing some of his his cppcon talks I can't forget his voice lol
@widnyj5561
@widnyj5561 Жыл бұрын
Great talk, but the amount of the audience talking was distracting
@ameerhamza4017
@ameerhamza4017 Жыл бұрын
Excellent Content. 🥰 Please Make a complete tutorials: How to implements the OS Concept in C++ like, Memory Allocation and De-Allocation, Memory Management, Process Shcedulling, Semaphorse, Mutex, Virtual Memory and Secure Coding Concept. If you have already uploaded this, Kindly do share the link. thanks
@ashleigh.
@ashleigh. 6 ай бұрын
Please please do not use this scheduler as a basis for your scheduler or thread pool, instead, have `sch.suspend()` (or better yet, `marshal()` and `yield()`) that returns an awaitable that will post the coroutine handle back onto the scheduler's queue or stack, otherwise your coroutine is forbidden from awaiting anything other than the scheduler. If you do await something else, then you will end up with a surreptitious resumption from the scheduler that accesses the incomplete awatable that was awaited. Additionally when the awaited thing completes, you will end up with a double `resume()` of your coroutine, causing all sorts of undefined behavior with the internal state machine
@nakedru
@nakedru 5 ай бұрын
This would be great if there weren't so many hecklers in the crowd. Let the man speak and ask questions later. Thank you. Nice presentation, Dian-lun.
C++ Coroutine Intuition - Roi Barkan - CppNow 2023
1:30:15
C++ Memory Model: from C++11 to C++23 -  Alex Dathskovsky
1:28:00
To Brawl AND BEYOND!
00:51
Brawl Stars
Рет қаралды 16 МЛН
VIP ACCESS
00:47
Natan por Aí
Рет қаралды 12 МЛН
Арыстанның айқасы, Тәуіржанның шайқасы!
25:51
QosLike / ҚосЛайк / Косылайық
Рет қаралды 650 М.
Godot Ocean Waves
6:40
AntzGames
Рет қаралды 12 М.
SIMD Libraries in C++ - Jeff Garland - CppNow 2023
1:30:07
CppNow
Рет қаралды 12 М.
C++20 Video
32:39
Piotr Gwioździk
Рет қаралды 46
Implementing a C++ Coroutine Task from Scratch - Dietmar Kühl - ACCU 2023
1:23:04