當前位置: 首頁>>代碼示例>>Python>>正文


Python uasyncio.sleep_ms方法代碼示例

本文整理匯總了Python中uasyncio.sleep_ms方法的典型用法代碼示例。如果您正苦於以下問題:Python uasyncio.sleep_ms方法的具體用法?Python uasyncio.sleep_ms怎麽用?Python uasyncio.sleep_ms使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在uasyncio的用法示例。


在下文中一共展示了uasyncio.sleep_ms方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: sleep

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def sleep(t, granularity=100):  # 100ms default
    if granularity <= 0:
        raise ValueError('sleep granularity must be > 0')
    t = int(t * 1000)  # ms
    if t <= granularity:
        await asyncio.sleep_ms(t)
    else:
        n, rem = divmod(t, granularity)
        for _ in range(n):
            await asyncio.sleep_ms(granularity)
        await asyncio.sleep_ms(rem)

# Anonymous cancellable tasks. These are members of a group which is identified
# by a user supplied name/number (default 0). Class method cancel_all() cancels
# all tasks in a group and awaits confirmation. Confirmation of ending (whether
# normally or by cancellation) is signalled by a task calling the _stopped()
# class method. Handled by the @cancellable decorator. 
開發者ID:peterhinch,項目名稱:micropython-mqtt,代碼行數:19,代碼來源:asyn.py

示例2: _as_read

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def _as_read(self, n, sock=None):  # OSError caught by superclass
        if sock is None:
            sock = self._sock
        data = b''
        t = ticks_ms()
        while len(data) < n:
            if self._timeout(t) or not self.isconnected():
                raise OSError(-1)
            try:
                msg = sock.read(n - len(data))
            except OSError as e:  # ESP32 issues weird 119 errors here
                msg = None
                if e.args[0] not in BUSY_ERRORS:
                    raise
            if msg == b'':  # Connection closed by host
                raise OSError(-1)
            if msg is not None:  # data received
                data = b''.join((data, msg))
                t = ticks_ms()
                self.last_rx = ticks_ms()
            await asyncio.sleep_ms(_SOCKET_POLL_DELAY)
        return data 
開發者ID:peterhinch,項目名稱:micropython-mqtt,代碼行數:24,代碼來源:mqtt_as.py

示例3: _as_write

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def _as_write(self, bytes_wr, length=0, sock=None):
        if sock is None:
            sock = self._sock
        if length:
            bytes_wr = bytes_wr[:length]
        t = ticks_ms()
        while bytes_wr:
            if self._timeout(t) or not self.isconnected():
                raise OSError(-1)
            try:
                n = sock.write(bytes_wr)
            except OSError as e:  # ESP32 issues weird 119 errors here
                n = 0
                if e.args[0] not in BUSY_ERRORS:
                    raise
            if n:
                t = ticks_ms()
                bytes_wr = bytes_wr[n:]
            await asyncio.sleep_ms(_SOCKET_POLL_DELAY) 
開發者ID:peterhinch,項目名稱:micropython-mqtt,代碼行數:21,代碼來源:mqtt_as.py

示例4: broker_up

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def broker_up(self):  # Test broker connectivity
        if not self.isconnected():
            return False
        tlast = self.last_rx
        if ticks_diff(ticks_ms(), tlast) < 1000:
            return True
        try:
            await self._ping()
        except OSError:
            return False
        t = ticks_ms()
        while not self._timeout(t):
            await asyncio.sleep_ms(100)
            if ticks_diff(self.last_rx, tlast) > 0:  # Response received
                return True
        return False 
開發者ID:peterhinch,項目名稱:micropython-mqtt,代碼行數:18,代碼來源:mqtt_as.py

示例5: start

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def start(self, user_task=None, awaitable=None):
        loop = asyncio.get_event_loop()
        while True:
            if not self._running:   # Restarting
                self.lstrx = []     # Clear down queues
                self.lsttx = []
                self._synchronised = False
                loop.create_task(self._run())  # Reset target (if possible)
                while not self._synchronised:  # Wait for sync
                    await asyncio.sleep_ms(100)
                if user_task is None:
                    while self._running:
                        await asyncio.sleep_ms(100)
                else:
                    await user_task(self)  # User task must quit on timeout
                    # If it quit for other reasons force a t/o exception
                    self.stop()
            await asyncio.sleep_ms(0)
            if awaitable is not None:  # User code may use an ExitGate
                await awaitable  # to ensure all coros have quit

# Can be used to force a failure 
開發者ID:peterhinch,項目名稱:micropython-mqtt,代碼行數:24,代碼來源:syncom.py

示例6: _send

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def _send(self, d):  # Write a line to socket.
        async with self._s_lock:
            start = utime.ticks_ms()
            while d:
                try:
                    ns = self._sock.send(d)  # OSError if client closes socket
                except OSError as e:
                    err = e.args[0]
                    if err == errno.EAGAIN:  # Would block: await server read
                        await asyncio.sleep_ms(100)
                    else:
                        self._verbose and print('_send fail. Disconnect')
                        self._evfail.set()
                        return False  # peer disconnect
                else:
                    d = d[ns:]
                    if d:  # Partial write: pause
                        await asyncio.sleep_ms(20)
                    if utime.ticks_diff(utime.ticks_ms(), start) > self._to:
                        self._verbose and print('_send fail. Timeout.')
                        self._evfail.set()
                        return False

            self._last_wr = utime.ticks_ms()
        return True 
開發者ID:peterhinch,項目名稱:micropython-iot,代碼行數:27,代碼來源:client.py

示例7: cond_go

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def cond_go():
    ntasks = 7
    barrier = Barrier(ntasks + 1)
    t1 = asyncio.create_task(cond01())
    t3 = asyncio.create_task(cond03())
    for n in range(ntasks):
        asyncio.create_task(cond02(n, barrier))
    await barrier  # All instances of cond02 have completed
    # Test wait_for
    barrier = Barrier(2)
    asyncio.create_task(cond04(99, barrier))
    await barrier
    # cancel continuously running coros.
    t1.cancel()
    t3.cancel()
    await asyncio.sleep_ms(0)
    print('Done.') 
開發者ID:peterhinch,項目名稱:micropython-samples,代碼行數:19,代碼來源:asyntest.py

示例8: readline

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def readline(s, timeout):
    line = b''
    start = utime.ticks_ms()
    while True:
        if line.endswith(b'\n'):
            if len(line) > 1:
                return line
            line = b''
            start = utime.ticks_ms()  # A blank line is just a  keepalive
        await asyncio.sleep_ms(100)  # See note above
        d = s.readline()
        if d == b'':
            raise OSError
        if d is not None:
            line = b''.join((line, d))
        if utime.ticks_diff(utime.ticks_ms(), start) > timeout:
            raise OSError 
開發者ID:peterhinch,項目名稱:micropython-samples,代碼行數:19,代碼來源:server.py

示例9: readline

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def readline(self):
        line = b''
        start = utime.ticks_ms()
        while True:
            if line.endswith(b'\n'):
                if len(line) > 1:
                    return line
                line = b''
                start = utime.ticks_ms()  # Blank line is keepalive
                self.led(not self.led())
            await asyncio.sleep_ms(100)  # nonzero wait seems empirically necessary
            d = self.sock.readline()
            if d == b'':
                raise OSError
            if d is not None:
                line = b''.join((line, d))
            if utime.ticks_diff(utime.ticks_ms(), start) > self.timeout:
                raise OSError 
開發者ID:peterhinch,項目名稱:micropython-samples,代碼行數:20,代碼來源:client_w.py

示例10: meter

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def meter(n, x, text, t):
    print('Meter {} test.'.format(n))
    m = Meter(wri, 5, x, divisions = 4, ptcolor=YELLOW,
              label=text, style=Meter.BAR, legends=('0.0', '0.5', '1.0'))
    l = LED(wri, ssd.height - 16 - wri.height, x, bdcolor=YELLOW, label ='over')
    while True:
        v = int.from_bytes(uos.urandom(3),'little')/16777216
        m.value(v, color(v))
        l.color(color(v))
        l.text(txt(v), fgcolor=color(v))
        refresh(ssd)
        await asyncio.sleep_ms(t) 
開發者ID:peterhinch,項目名稱:micropython-nano-gui,代碼行數:14,代碼來源:asnano.py

示例11: flash

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def flash(n, t):
    led = pyb.LED(n)
    while True:
        led.toggle()
        await asyncio.sleep_ms(t) 
開發者ID:peterhinch,項目名稱:micropython-nano-gui,代碼行數:7,代碼來源:asnano.py

示例12: killer

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def killer(tasks):
    sw = pyb.Switch()
    while not sw():
        await asyncio.sleep_ms(100)
    for task in tasks:
        task.cancel() 
開發者ID:peterhinch,項目名稱:micropython-nano-gui,代碼行數:8,代碼來源:asnano.py

示例13: flash

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def flash(n, t):
    led = pyb.LED(n)
    try:
        while True:
            led.toggle()
            await asyncio.sleep_ms(t)
    except asyncio.CancelledError:
        led.off()  # Demo tidying up on cancellation. 
開發者ID:peterhinch,項目名稱:micropython-nano-gui,代碼行數:10,代碼來源:asnano_sync.py

示例14: wait

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def wait(self, t):
        while t >= 0:
            if self.sw():
                return True
            await asyncio.sleep_ms(50)
            t -= 50
        return False

# The main task instantiates other tasks then does the display update process. 
開發者ID:peterhinch,項目名稱:micropython-nano-gui,代碼行數:11,代碼來源:asnano_sync.py

示例15: acquire

# 需要導入模塊: import uasyncio [as 別名]
# 或者: from uasyncio import sleep_ms [as 別名]
def acquire(self):
        while True:
            if self._locked:
                await asyncio.sleep_ms(self.delay_ms)
            else:
                self._locked = True
                break 
開發者ID:peterhinch,項目名稱:micropython-mqtt,代碼行數:9,代碼來源:asyn.py


注:本文中的uasyncio.sleep_ms方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。