[Python-Dev] PEP 492: What is the real goal? (original) (raw)

Jim J. Jewett jimjjewett at gmail.com
Fri May 1 20:26:28 CEST 2015


On Thu, Apr 30, 2015 at 3:32 PM, Guido van Rossum <guido at python.org> wrote:

(me:)

A badly worded attempt to say Normal generator: yield (as opposed to return) means that the function isn't done, and there may be more things to return later.

but an asynchronous (PEP492) coroutine is primarily saying:

"This might take a while, go ahead and do something else meanwhile."

(Yuri:) Correct.

(Guido:)> Actually that's not even wrong. When using generators as coroutines, PEP 342

style, "yield" means "I am blocked waiting for a result that the I/O multiplexer is eventually going to produce".

So does this mean that yield should NOT be used just to yield control if a task isn't blocked? (e.g., if its next step is likely to be long, or low priority.) Or even that it wouldn't be considered a co-routine in the python sense?

If this is really just about avoiding busy-wait on network IO, then coroutine is way too broad a term, and I'm uncomfortable restricting a new keyword (async or await) to what is essentially a Domain Specific Language.

-jJ



More information about the Python-Dev mailing list