|
|
|
|
|
by insanitybit
1008 days ago
|
|
> As I understand it's not possible in Rust async model, You can block, you're just going to block all other futures that are executed on that same underlying thread. But all sorts of things block, for loops block. This is the same as Java, I believe. Akka also has special actors called IO Workers that are designed for blocking work - Rust has the same thing with `spawn_blocking`, which will place the work onto a dedicated threadpool. > So in reality you don't interrupt or clean up anything in Rust when a timeout happens You don't interrupt, you are yielded to. It's cooperative. > I wonder what happens with resources if there were allocated. When a Future is dropped its state is dropped as well, so they are all freed. |
|
Having said that, Erlang exists and doing well, so async is as good as any model designed for special cases. But this discussion basically answers the question
> Why don’t people like async?
Because not everybody (which means a majority of developers) needs this complexity. And the upward poisoning means that I can't block in my function if my web server is based on async, which affects everybody who is using it.