No video

KotlinConf 2017 - Introduction to Coroutines by Roman Elizarov

  Рет қаралды 123,687

JetBrains

JetBrains

Күн бұрын

We live in an asynchronous era of concurrency. Modern front-end and mobile applications provide real-time feedback and communication, server-side applications and services handle thousands of online users while integrating dozens of micro-services. Old-school monolithic applications with thread-based concurrency are going out of fashion, and asynchronous styles of programming with callbacks, futures, reactive streams and coroutines are gaining popularity.
Kotlin is a modern and pragmatic JVM language that is developed by JetBrains with a strong emphasis on Java interoperability. Due to its strong Java interop, any Java asynchronous library can be used in Kotlin. You can even use JVM-based byte-code-instrumenting coroutine implementations like Quasar and JavaFlow. So, why has Kotlin introduced coroutines as a first-class language feature and how are Kotlin coroutines different from the generate/yield and async/await coroutines in C#, Python, JS and other languages? What makes using coroutines in Kotlin different from using threads?
This talk answers those questions and gives a gentle introduction to the world of Kotlin coroutines with live examples. You'll learn how to launch and wait for coroutine completion, what are Kotlin suspending functions and how to wrap your favorite asynchronous library into them, turning your asynchronous "callback hell" into an easy-to-read synchronous-like code. You'll see how you can write scalable applications with Kotlin coroutines to handle lots of concurrent actions (connections, users, conversations, animations, etc.) at once.
Roman Elizarov is a professional software developer with more than 16 years experience. He started his career at Devexperts, where he designed and developed high-performance trading software for leading brokerage firms and market data delivery services that routinely handle millions of events per second. He is an expert in Java and JVM, particularly in real-time data processing, algorithms and performance optimizations for modern architectures.
Roman currently works on the Kotlin language at JetBrains. Having worked on very large systems comprising of many modules written in different languages, he has a dream of a single language that can be used to write all parts of a very large distributed system, to share and reuse data models and algorithms without friction. Kotlin with JVM and JS backends and the upcoming native compiler is the ideal candidate to realize this dream.
In 2000 Roman had graduated from St. Petersburg ITMO. He now teaches a course on concurrent and distributed programming in ITMO. During his undergraduate study, he participated at ACM International Collegiate Programming Contest (ICPC). Since 1997 and until now Roman serves as a Chief Judge of Northeastern European Regional Programming Contest (NEERC) of ACM ICPC.

Пікірлер: 71
@igorg.8624
@igorg.8624 6 жыл бұрын
This is definitely a well-polished talk. It made Coroutines easy to understand, and the speaker is obviously well versed.
@ZelenoJabko
@ZelenoJabko 3 жыл бұрын
Well Polish-ed talk
@drakekason3928
@drakekason3928 3 жыл бұрын
InstaBlaster.
@zhou7yuan
@zhou7yuan 5 жыл бұрын
Asynchronous programming [0:50] A toy problem [1:48] token -> post -> process Threads [2:54] (how many threads we can have?) Callbacks to the rescue (sort of...) [4:23] Callbacks: before [4:34] Callbacks: after [5:11] (aka "callback hell". exceptions is a mess...) Futures/Promises/Rx to the rescue (sort of...) [6:25] Futures: before & after [6:51] Futures: after (3) [7.33] (but all those combinators...) Kotlin coroutines to the rescue [9:03] Coroutines: before [9:12] Coroutines: after [10:09] Bonus features [11:18] (Regular loops, exception handing, higher-order functions) (Everything like in blocking code) Suspending functions [12:44] Retrofit async [13:04] Composition (beyond sequential) [14:43] Higher-order functions [15:31] (retryIO{}) (suspend fun retryIO(block: suspend() -> T): T{}) Coroutine builders [16:57] Coroutines revisited [17:06] launch (coroutine builder) [18:13] (Fire and forget!) UI Context [19:22] Where's the magic of launch? [19:55] async/await [21:07] Kotlin-way [21:34] Classic-way [21:41] (async/await) (C#, Python, TS, Dart, coming to JS) (C#) (returns a future) Why no await keyword in Kotlin? [23:01] The problem with async (default async without `await` calling) Kotlin suspending functions are designed to imitate sequential behavior by default [24:53] (Concurrency is hard, has to be explicit) Kotlin approach to async (Concurrency where you need it) [25:28] Use-case for async [25:44] Kotlin async function [26:40] (Deferred - Kotlin's future type) (async coroutine builder) (await function) Using async function when needed [29:10] (suspend fun l(); async{ l() }) Kotlin approach to async [30:08] Coroutines [30:48] What are coroutines conceptually? [31:14] (very light-weight threads) Example [31:33] (runBlocking{} runs coroutine in the context of invoker thread) Demo [33:16] (Example with thread) [34:06] (Demo with thread) [34:50] (OutOfMemoryError) Java interop[35:54] (future{} coroutine builder) [37:33] (future1.await() - Extension for Java's CompletableFuture) Beyond asynchronous code [38:14] Fibonacci sequence [38:31] (buildSequence{} yield()) (Coroutine is restricted only to suspending functions defined here) Synchronous [40:07] (Synchronous with invoker) Library vs Language [41:24] Classic async [41:37] Kotlin coroutines [41:54] Experimental status [42:41]
@Ab-no6rz
@Ab-no6rz 3 жыл бұрын
God bless you
@ravindraverma8413
@ravindraverma8413 2 жыл бұрын
Thanks Bro
@harshagarwal00
@harshagarwal00 11 ай бұрын
you are god sent!
@dansadventures5514
@dansadventures5514 6 жыл бұрын
This was one of the best videos I've seen on coroutines as it really helped me get a sense for how I would use them in practice. Thank you!
@methodsignature
@methodsignature 6 жыл бұрын
Excellent! This is exactly the talk I wanted. The what, the why, and the promise presented in a thoughtful and concise fashion.
@vipullal7689
@vipullal7689 3 жыл бұрын
Another brilliant and comprehensive talk. I now understand coroutines. Thanks a ton!
@JetBrainsTV
@JetBrainsTV 3 жыл бұрын
You're very welcome!
@AlexGLuque
@AlexGLuque 6 жыл бұрын
Thank you for posting this talk. It's the best initial approach I've seen so far after some weeks of reading about the coroutines. Great speaker for a great language!
@alekseimulin6151
@alekseimulin6151 5 жыл бұрын
Jet Brains guys, you're great, I think it's a breakthrough and a way cooler concept than anything else at the moment.
@carrefamily01
@carrefamily01 6 жыл бұрын
Great presentation and a even greater product by Jetbrains! Kudos to the kotlin team! Can't wait to use coroutines in my project.
@ChrisAthanas
@ChrisAthanas 5 жыл бұрын
Excellent presentation by an obvious master of his craft
@kdbrian.d3v
@kdbrian.d3v 3 ай бұрын
i watched this 6 years later and if am being real its worth 1000 videos. Really laid the basis of coroutines.
@sleepydev4700
@sleepydev4700 4 жыл бұрын
I've seen other tutorials but this is the best explanation of them
@guptaanmol184
@guptaanmol184 2 жыл бұрын
Wow, way to go kotlin with saner defaults! Amazing work! ~ from a C# dev using async await :)
@xpopcornx1747
@xpopcornx1747 5 жыл бұрын
C# is much more clear. When you call an async function you use await, in kotlin there is no difference between how you call a suspend function and non suspend function so there is no way of telling what the code does, you have to manually go to each function and check if it is a suspend function to know that it is waiting for something.
@MartinNordholts
@MartinNordholts 5 жыл бұрын
XPopCornX This is touched upon in the talk. The solution is to have the IDE mark suspend calls in the left gutter on a line by line basis.
@centurieswisdom
@centurieswisdom 6 жыл бұрын
Please, fix the volume of the intro music and the volume of record itself!
@MarcusWolschon
@MarcusWolschon 6 жыл бұрын
Next time: repeat the questions into a microphone!
@saurabh75prakash
@saurabh75prakash 4 жыл бұрын
This is exactly what I was looking for. Thanks!
@tahirraza2590
@tahirraza2590 Жыл бұрын
A bit old but still related and on-point. Really liked the way he presented the whole thing as a story. The what, they why and the how.
@CarlitoProductions
@CarlitoProductions 6 жыл бұрын
Can you use a coroutine by not passing any arguments, and doing a while loop inside of the suspended coroutine (for example a person messes their information up during a prompt and needs to reset, so the while loop continues until they press yes)?
@yakiv1488
@yakiv1488 3 жыл бұрын
Thanks a lot. That's a really good talk!
@lloydryandavid7820
@lloydryandavid7820 5 жыл бұрын
Very well explained. Thanks for the video! 👍
@md.tahmidmozaffar9135
@md.tahmidmozaffar9135 4 жыл бұрын
Very good presentation.
@unrealspetznaz
@unrealspetznaz 4 жыл бұрын
really helpful
@TheWitzig
@TheWitzig 6 жыл бұрын
Such a great video! Thank you! :-)
@AntonDerevyanko
@AntonDerevyanko 6 жыл бұрын
Thanks for clear and understandable talk.
@Rjbcc
@Rjbcc 5 жыл бұрын
I must be missing something very basic here but what is the point of making the first example asynchronous? If we need to create a `Post` before we can process it, and we need to create a `Token` before we can create a `Post`, isn't this a set of synchronous operations? What will actually be done asynchronously? Are we saying we want the entire operation of create/post/process to be async while the app does something else?
@GooksanGom
@GooksanGom 3 жыл бұрын
UI interactions I think
@Rjbcc
@Rjbcc 8 ай бұрын
Back to answer my own question 4 years later. Yes the Post example consists of sequential operations that are not executed concurrently, the whole operation can be launched asynchronously inside of a coroutine, and not be thread bound at any IO suspension point. The async part is the whole operation, and the suspending operations allow us to free up threads to do other work instead of blocking on network IO.
@hagbardceline9866
@hagbardceline9866 6 жыл бұрын
Interesting talk! But i don't really see the improvement from the first - rightfully - criticized approach of having "to many" combinators to "remember" in the promise/future/Rx case when in fact i have the same thing with the so called coroutine builders. This is not really compelling, at least the talk does not make it clear to me why i should trade like 3 combinators with 3 coroutine builders ( i oversimplified this here )
@vangrails
@vangrails 6 жыл бұрын
Maybe the handling of exceptions is easier?
@robchr
@robchr 6 жыл бұрын
So coroutines are just monads where suspend functions are Kleisli arrows, '=' is 'flatMap' and 'await' is 'pure'. Got it ;-)
@methodsignature
@methodsignature 6 жыл бұрын
Us functional casuals needed all the other words in between.
@rckd5903
@rckd5903 5 жыл бұрын
wow, kotlin has async/await too :-D
@houssemzaier
@houssemzaier 3 жыл бұрын
They are in higher lever when you compare them to other languages. async and await are functions not keywords. And this is way better! If you understand
@vulnerable_content
@vulnerable_content 3 жыл бұрын
Thank you!
@kc2815
@kc2815 6 жыл бұрын
Wait wait wait... So in the code where he has the two calls to loadImageAsync() and then calls await on the two deferred objects one after the other, is that really asynchronous? Wouldn't the first call suspend until it was completed and then call the second one? Or does the loading happen when the function is invoked and then the await call only makes sure the call completes before moving to the next line?
@henninghoefer
@henninghoefer 6 жыл бұрын
Kevin Colin Both images are loaded asynchronously at virtually the same time, only the await() are blocking and ensure both images are there before combining them.
@crazieeez
@crazieeez 6 жыл бұрын
When you are confuse, the programming language is garbage. Coroutine is garbage.
@user-do4oh6rw9u
@user-do4oh6rw9u 6 жыл бұрын
so RX Java is garbage too, because everyone is confused firstly)
@a0um
@a0um 5 жыл бұрын
I've struggled to hear the speaker even maxing out my phone volume. I found the example contrived: what's the point of making those functions async? I agree the "suspend" keyword isn't the one I would have expected. This is my first exposure to coroutines and I'm gonna leave half way. Still exited about Kotlin though, and I'll be looking for other introductions to coroutines.
@pedrod.8839
@pedrod.8839 6 жыл бұрын
Where can I find the talk where he shows how coroutines are compiled in the JVM?
@JetBrainsTV
@JetBrainsTV 6 жыл бұрын
Is this the one you are looking for? kzfaq.info/get/bejne/j9iiiKaEzp2WdWw.html
@BradMcHelm
@BradMcHelm 6 жыл бұрын
please check out the flashing icons, giving me epilepsy
@mayureshgharat1600
@mayureshgharat1600 2 жыл бұрын
I am wondering how is the launch function at 20:41 different the previous retryIO function. Why does retryIO need to be a suspend function?
@ColinTheShots
@ColinTheShots 6 жыл бұрын
Will the slides be shared? Thanks!
@JetBrainsTV
@JetBrainsTV 6 жыл бұрын
www.slideshare.net/elizarov/introduction-to-coroutines-kotlinconf-2017
@ColinTheShots
@ColinTheShots 6 жыл бұрын
Thanks!
@kristofs8893
@kristofs8893 2 жыл бұрын
Kotlin is very good from programming, way quicker than Java. I studied Java at Uni in London, but still there is a lot still to be learnt. Very interesting the fact that Kotlin is built on top of JVM.
@abunapha
@abunapha 5 жыл бұрын
The generated subtitles are hilarious
@JetBrainsTV
@JetBrainsTV 5 жыл бұрын
Any examples to make us smile?
@abunapha
@abunapha 5 жыл бұрын
@@JetBrainsTV 19:24 "lunch curtain builder" Also Kotlin is always "catalan"
@JetBrainsTV
@JetBrainsTV 5 жыл бұрын
@@abunapha "lunch curtain builder" - That's hilarious!
@SpectatorAlius
@SpectatorAlius 3 жыл бұрын
He keeps pronouncing 'coroutine' as 'car routine' -- and I finally guessed why! He must have learned Russian in Moscow or somewhere else nearby with a pronounced акане accent!
@ybtoo7
@ybtoo7 3 жыл бұрын
Everything is good except for speakers English accent. Its been tough to follow here and there due to lack of clean pronunciation, but can figure out of the context. Should have provided properly generatedsubtitles. Except this rest is wonderful.
@garywzh
@garywzh 6 жыл бұрын
great talk
@dnkilic
@dnkilic 4 жыл бұрын
More recent one is here; kzfaq.info/get/bejne/nshgm8l5u72ng2Q.html
@miracledoh4020
@miracledoh4020 3 жыл бұрын
comparing coroutine with Thread is pointless, coroutine's java equivalent should be Executor
@StefanReich
@StefanReich 5 жыл бұрын
Yeah it's a good idea (coroutines). I also started adding them to Java at some point... didn't complete the project yet, but it may be to come. dzone.com/articles/java-can-have-coroutines
@kemuri22
@kemuri22 6 жыл бұрын
kinda like apple's gcd
@typingcat
@typingcat 2 жыл бұрын
Stop starting a lecture video with a useless loud long music sequence.l
@aprofromuk
@aprofromuk 6 жыл бұрын
cheesiest crapiest startest music ever :)
@crazieeez
@crazieeez 6 жыл бұрын
coroutines look like garbage. the syntax is incredibly complicated to try to simplify async operation. Get your naming right and stop with a bunch of non alphabet characters to confuse people. The explanation given in this video is garbage. Author tries to use adjective to express how kotlin coroutines are better than async/await and how much simpler ... I don't buy it. suspend is a dumb name to give to a function for async operation ... suspend means don't run the function.
@rckd5903
@rckd5903 5 жыл бұрын
crazieeez exactly what i thought 😂
@valour.se47
@valour.se47 5 жыл бұрын
Easy man 👨
@davidkerr7
@davidkerr7 5 жыл бұрын
I think it because JavaScript already has Async and wait keywords
Алексей Щербаков разнес ВДВшников
00:47
WORLD'S SHORTEST WOMAN
00:58
Stokes Twins
Рет қаралды 169 МЛН
Lifecycles, Coroutines and Scopes | Alejandro Serrano Mena
38:25
Kotlin by JetBrains
Рет қаралды 10 М.
Роман Елизаров - Корутины в Kotlin
59:04
JPoint, Joker и JUG ru
Рет қаралды 63 М.
Headache-Free Reactive Programming With Spring Boot and Kotlin Coroutines
54:21
Roman Elizarov - Structured concurrency
1:00:01
Hydra
Рет қаралды 25 М.
Kotlin Coroutines 101 - Android Conference Talks
24:49
Android Developers
Рет қаралды 134 М.
003. Корутины в Kotlin - Роман Елизаров, JetBrains
1:13:34
Yandex for Developers
Рет қаралды 37 М.
Kotlin & Functional Programming: pick the best, skip the rest by Urs Peter
43:49
Why Isn't Functional Programming the Norm? - Richard Feldman
46:09