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: 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: References: From: Saimadhav Heblikar Date: Thu, 24 Jul 2014 10:45:04 +0530 Subject: Re: Question about asyncio doc example To: Terry Reedy , 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 List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Newsgroups: comp.lang.python Message-ID: 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 On 24 July 2014 05:54, Terry Reedy 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