Async Rust: the good, the bad, and the ugly - Steve Klabnik
ฝัง
- เผยแพร่เมื่อ 20 พ.ย. 2024
- Presented at All Things Open 2023
Presented by Steve Klabnik - Oxide Computer Company
Title: Async Rust: the good, the bad, and the ugly
Abstract: Rust's async/await feature shipped in 2018 in an MVP state. Since then, a lot have things have changed, and there's a lot more work to do. In this talk, Steve will talk frankly about the design of async/await in Rust, its strengths, its weaknesses, and lessons learned from using it in production.
About All Things Open
All Things Open is a universe of open source events and platforms designed to educate and connect technologists around the world. It includes the All Things Open conference, the largest open source / tech / web event on the U.S. East Coast, meetups in the Research Triangle Park (RTP) of NC, South Carolina, and New York City, and a TH-cam channel with more than 1,000 free recordings. See everything we do at allthingsopen.org.
Join our meetups:
New York City meetup: www.meetup.com...
South Carolina meetup: www.meetup.com...
Research Triangle Park, NC meetup: www.meetup.com...
Follow All Things Open:
TH-cam: / allthingsopen
LinkedIn: / all-things-open
Instagram: / allthingsopen
Facebook: / allthingsopen
Twitter: / allthingsopen
rust's use of await is a big insight! i love it
Start at 17:30 for Async info
thanks
Minor correction: Swift also has async await and a built-in tokio-like runtime and is not a garbage collected language.
I think the joke failed at 2:30. The slide says "two raised to the power of its position" - which means 2^0 = 1 .
And not the other way around.
Still, the joke stands. Meaning only one would talk about it.
You do realize that the numbers are proportional to the time spent discussing the associated feature not the number of individuals discussing it@@zeroows
he put that there for the compiler-programmer watchers to error out on. smart.
Off by one error
@@heavenlyactsatheavycost7629 It's actually anyone who knows this subset of math.
I did not know that you can use async await in embedded rust without an allocator. That's VERY cool. Going to have to look for cancellation problems in my code. Haven't had any bugs, but I might just be getting lucky.
Wadlers Law seems to be quite similar to Bikeshedding
Yeah, I got rid of my bike ages ago. Shed your bike!
2 to the power of 0 being 1 and not 0 is the only feedback I'm gonna give this talk, and there is nothing you can do about it ;-)
great talk!!
I still think that async rust should have stayed in library space. There was no need to bake the syntactic sugar in to the language.
19:55 erm, actually, its rust += 1
Who says its an assignment? The ++ in C++ can be overloaded to do just about anything.
god i love nerds beefing
Such an interesting talk, but such a shitty sound quality 🙉🙉
Well… this talk took too long to get things going. I don’t know why people think that talks should be funny. They should be interesting instead.
More than halfway through, and I'm still awaiting the future that contains the subject matter declared in the title. On the other hand I know a ton about the speaker.
@@br9809😅 0:24 am😊w whw
You must be fun at parties.
something().await makes it look like you're running a synchronous function, getting a result, and then accessing `await` on that. It fundamentally goes against assumed order of execution for nested statements. It might be nicer not to have to wrap `(await something())` for specific situations, but at least people would know in what order things are running.
The monads / ? exception bubbling and all the rest are irrelevant to the question of what someone would naturally assume the code is doing, even in regards to internal consistency of the language syntax.
(await something()) is not the solution you want if you don't want await to look like a field you access after polling to completion and getting the result. You would want await(_), or (_.await()), or something like that, but this would also be new weird exceptional syntax the same way (await _) or (_.await) is. Your problem here is literally just the weird assumption that .await can only be read as field access, and that (await _) is inherently readable. I think this is both a superficial discussion, but also a bad argument that relies on the assumption that (await _) is readable, which I disagree with.
that is quite literally what you do though. you access a function that returns a Future synchronously. Then you tell you executor to start working on it. without await nothing would happen.
i don't want to write async code and think about the execution order: i want to describe a data processing pipeline. I want to think declaratively. For example, with webflux on Java, you flatMap a Mono to say, “run another async task and extract the result”. In scala, you flatMap optional to extract the value, or flatMap lists of lists, or flatMap async tasks to say “flatten the containing handle to what it contains”, which is perfect for thinking about async tasks from a declarative perspective - i don't care about the wrappers. When they happen, i care about the results. Functional programming for the win 😊
Just use C ffs