Dieser Artikel bietet Ihnen eine Einführung in die synchrone und asynchrone E/A in Python. Ich hoffe, dass er Ihnen als Referenz dienen wird.
Coroutine ist eine empfohlene Programmiermethode in Tornado. Mit Coroutine können Sie einfachen und effizienten asynchronen Verarbeitungscode entwickeln.
Wie wir alle wissen, ist die Betriebseffizienz der CPU höher als die des Festplattenspeichers und höher als die der Netzwerkanforderungen, was zur Verarbeitung und Speicherung der CPU führt Die Geschwindigkeit der Netzwerkanforderungen (E/A-Vorgänge) ist inkonsistent. Zu diesem Zeitpunkt können Sie zwischen synchronen und asynchronen E/A-Vorgängen wählen.
Synchrone E/A-Vorgänge führen dazu, dass der Prozess blockiert, bis der E/A-Vorgang abgeschlossen ist.
Asynchrone E/A-Vorgänge führen nicht dazu, dass der anfordernde Prozess blockiert.
Code:
#导入Tornado的HTTP客户端 from tornado.httpclient import HTTPClient def synchronous_visit(): http_client=HTTPClient() #阻塞,知道对网址访问完成 respone=http_client.fetch("http://www.baidu.com") print(respone.body) synchronous_visit()
HTTPClient ist Tornatos synchroner Zugriffs-HTTP-Client. Die Funktion synchronous_visit() im obigen Code verwendet einen typischen synchronen E/A-Vorgang, um auf die URL zuzugreifen. Die Ausführungszeit dieser Funktion hängt von der Netzwerkgeschwindigkeit und der Antwortgeschwindigkeit des anderen Servers ab Nachdem das Ergebnis erhalten wurde, kann diese Funktion ausgeführt werden.
from tornado.httpclient import AsyncHTTPClient def handle_response(response): print(response.body) def asyncronous_visit(): http_client=AsyncHTTPClient() http_client.fetch("http://www.baoidu.com",callback=handle_response)
AsyncHTTPClient ist Tornados HTTP-Client für asynchronen Zugriff. In der Funktion asynchronous_visit() im obigen Code wird AsyncHTTPClient verwendet, um asynchron auf die Website eines Drittanbieters zuzugreifen. Die Funktion http_client.fetch() kehrt sofort nach dem Aufruf zurück, ohne auf den Abschluss des tatsächlichen Zugriffs zu warten, was zu asynchronous_visit( führt. ) wird ebenfalls sofort ausgeführt. Wenn der Zugriff auf die URL tatsächlich abgeschlossen ist, ruft AsyncHTTPClient die durch den Callback-Parameter angegebene Funktion auf, in der die Zugriffsergebnisse verarbeitet werden können.
Das obige ist der detaillierte Inhalt vonEinführung in die synchrone und asynchrone E/A von Tornado in Python (mit Beispielen). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!