Platform Support

Theasyncio module is designed to be portable,but some platforms have subtle differences and limitationsdue to the platforms’ underlying architecture and capabilities.

All Platforms

Windows

Source code:Lib/asyncio/proactor_events.py,Lib/asyncio/windows_events.py,Lib/asyncio/windows_utils.py


Changed in version 3.8:On Windows,ProactorEventLoop is now the default event loop.

All event loops on Windows do not support the following methods:

SelectorEventLoop has the following limitations:

ProactorEventLoop has the following limitations:

The resolution of the monotonic clock on Windows is usually around 15.6milliseconds. The best resolution is 0.5 milliseconds. The resolution depends on thehardware (availability ofHPET) and on theWindows configuration.

Subprocess Support on Windows

On Windows, the default event loopProactorEventLoop supportssubprocesses, whereasSelectorEventLoop does not.

Thepolicy.set_child_watcher() function is alsonot supported, asProactorEventLoop has a different mechanismto watch child processes.

macOS

Modern macOS versions are fully supported.

macOS <= 10.8

On macOS 10.6, 10.7 and 10.8, the default event loopusesselectors.KqueueSelector, which does not supportcharacter devices on these versions. TheSelectorEventLoopcan be manually configured to useSelectSelectororPollSelector to support character devices onthese older versions of macOS. Example:

importasyncioimportselectorsselector=selectors.SelectSelector()loop=asyncio.SelectorEventLoop(selector)asyncio.set_event_loop(loop)