Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > comp.lang.python > #75123

Re: Question about asyncio doc example

Path csiph.com!v102.xanadu-bbs.net!xanadu-bbs.net!feeder.erje.net!eu.feeder.erje.net!newsfeed.xs4all.nl!newsfeed1a.news.xs4all.nl!xs4all!newsgate.cistron.nl!newsgate.news.xs4all.nl!post.news.xs4all.nl!not-for-mail
Return-Path <saimadhavheblikar@gmail.com>
X-Original-To python-list@python.org
Delivered-To python-list@mail.python.org
X-Spam-Status OK 0.005
X-Spam-Evidence '*H*': 0.99; '*S*': 0.00; 'context': 0.07; 'subject:Question': 0.07; 'def': 0.12; 'jan': 0.12; 'blocking': 0.16; 'clears': 0.16; 'itself,': 0.16; 'loop.': 0.16; 'non- blocking': 0.16; 'operation),': 0.16; 'operation,': 0.16; 'reedy': 0.16; 'subject:doc': 0.16; 'substitute': 0.16; 'true:': 0.16; 'wrote:': 0.18; 'bit': 0.19; 'code,': 0.22; 'input': 0.22; 'example': 0.22; 'import': 0.22; 'example.': 0.24; 'question': 0.24; 'equivalent': 0.26; 'shown': 0.26; 'header:In-Reply-To:1': 0.27; 'to:2**1': 0.27; 'function': 0.29; 'feature': 0.29; 'am,': 0.29; 'statement': 0.30; 'message-id:@mail.gmail.com': 0.30; 'url:mailman': 0.30; 'included': 0.31; 'getting': 0.31; 'url:python': 0.33; "i'd": 0.34; 'something': 0.35; 'received:google.com': 0.35; 'there': 0.35; 'really': 0.36; 'i.e.': 0.36; 'yield': 0.36; 'url:listinfo': 0.36; 'shows': 0.36; 'hi,': 0.36; 'url:org': 0.36; 'url:library': 0.38; 'to:addr :python-list': 0.38; 'to:addr:python.org': 0.39; 'url:mail': 0.40; 'how': 0.40; 'skip:u 10': 0.60; 'url:3': 0.61; 'real': 0.63; 'july': 0.63; 'dont': 0.67; 'behavior': 0.77
DKIM-Signature v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :content-type; bh=7dqtd9gBsWZU9n6a9FnSGULN2sCPSKKBckfQQmP4kLU=; b=ugcC/UE5P5Td0WLD/JrROwGNHnFUtyVKzdphPwlO8J5Pp1p36iaHYll7R1BOMAdUCS L3felj6vUfO8cQ6eTkaQALHxIrcpPXDNcYMEvkdpT2gP2womgdSlCKSFlIx+zGev7+rP gZIx5UhHWH9ZWZeTui8Y+PA0io2Ft0gSfzljRMJtA41RnNm2QBgeNLyEdUhgPWDB6tfe GOMnBRwr4N1IlMdIR0NFWBWx9uVC8zWdpQNSbyTRNCBg9y7s0ovOss/tR/Vs/4AEev9q FHFJH3Y9p4q07nFpCFA0jx5F3nxH+vIGRElHYaHqphsRssEvRYt5Q6tr6E23TLtZx0BD q8+w==
X-Received by 10.181.13.112 with SMTP id ex16mr31505830wid.58.1406178944695; Wed, 23 Jul 2014 22:15:44 -0700 (PDT)
MIME-Version 1.0
In-Reply-To <lqpjnu$dun$1@ger.gmane.org>
References <CAO3PiBgEsjvWMMqZkkOUoHmyDQr4=BtprspHj1kw7itOMiZDpw@mail.gmail.com> <lqpjnu$dun$1@ger.gmane.org>
From Saimadhav Heblikar <saimadhavheblikar@gmail.com>
Date Thu, 24 Jul 2014 10:45:04 +0530
Subject Re: Question about asyncio doc example
To Terry Reedy <tjreedy@udel.edu>, python-list@python.org
Content-Type text/plain; charset=UTF-8
X-BeenThere python-list@python.org
X-Mailman-Version 2.1.15
Precedence list
List-Id General discussion list for the Python programming language <python-list.python.org>
List-Unsubscribe <https://mail.python.org/mailman/options/python-list>, <mailto:python-list-request@python.org?subject=unsubscribe>
List-Archive <http://mail.python.org/pipermail/python-list/>
List-Post <mailto:python-list@python.org>
List-Help <mailto:python-list-request@python.org?subject=help>
List-Subscribe <https://mail.python.org/mailman/listinfo/python-list>, <mailto:python-list-request@python.org?subject=subscribe>
Newsgroups comp.lang.python
Message-ID <mailman.12265.1406179417.18130.python-list@python.org> (permalink)
Lines 69
NNTP-Posting-Host 2001:888:2000:d::a6
X-Trace 1406179417 news.xs4all.nl 2901 [2001:888:2000:d::a6]:42805
X-Complaints-To abuse@xs4all.nl
Xref csiph.com comp.lang.python:75123

Show key headers only | View raw


On 24 July 2014 05:54, Terry Reedy <tjreedy@udel.edu> wrote:
> On 7/23/2014 6:43 AM, Saimadhav Heblikar wrote:
>>
>> Hi,
>>
>> The example in question is
>>
>> https://docs.python.org/3/library/asyncio-task.html#example-hello-world-coroutine.
>> I'd like to learn the purpose of the statement
>> "yield from asyncio.sleep(2)" in that example.
>>
>> In particular, I'd like to know if asyncio.sleep() is used as a
>> substitute for slow/time consuming operation, i.e. in real code,
>> whether there will be a real time consuming statement in place of
>> asyncio.sleep().
>
>
> The context is
>     while True:
>         print('Hello')
>         yield from asyncio.sleep(3)
>
> sleep is both itself, to shown to schedule something at intervals in a
> non-blocking fashion, as well as a placefiller.  The blocking equivalent
> would use 'time' instead of 'yield from asyncio'. The following shows the
> non-blocking feature a bit better.
>
> import asyncio
>
> @asyncio.coroutine
> def hello():
>     while True:
>         print('Hello')
>         yield from asyncio.sleep(3)
>
> @asyncio.coroutine
> def goodbye():
>     while True:
>         print('Goodbye')
>         yield from asyncio.sleep(5.01)
>
> @asyncio.coroutine
> def world():
>     while True:
>         print('World')
>         yield from asyncio.sleep(2.02)
>
> loop = asyncio.get_event_loop()
> loop.run_until_complete(asyncio.wait([hello(), goodbye(), world()]))
>
> Getting the same time behavior in a while...sleep loop requires reproducing
> some of the calculation and queue manipulation included in the event loop.
>
> --
> Terry Jan Reedy
>
> --
> https://mail.python.org/mailman/listinfo/python-list

That clears it up for me. For situations where I dont really know how
long a function is going to take(say waiting for user input or a
network operation), I am better off using callbacks than "yield from
asyncio.sleep()". Is my understanding correct?



-- 
Regards
Saimadhav Heblikar

Back to comp.lang.python | Previous | NextNext in thread | Find similar | Unroll thread


Thread

Re: Question about asyncio doc example Saimadhav Heblikar <saimadhavheblikar@gmail.com> - 2014-07-24 10:45 +0530
  Re: Question about asyncio doc example Marko Rauhamaa <marko@pacujo.net> - 2014-07-24 08:54 +0300

csiph-web