前回の IoP アップデートからしばらく時間が経ちました。 追いつきましょう!
IoP コマンドライン インターフェイスに大幅な機能強化が追加されました。
-
名前の変更: プロジェクトの新しいブランドに合わせて、
grongier.pex
モジュールの名前がiop
に変更されました。 - 非同期サポート: IoP は非同期関数とコルーチンを完全にサポートするようになりました。
プロジェクト名の変更
grongier.pex
モジュールは下位互換性のためにアクセス可能なままですが、将来のリリースでは削除される予定です。 新規開発には iop
モジュールを使用します。
非同期機能
IoP は長い間非同期呼び出しをサポートしてきましたが、以前は非同期関数とコルーチンを直接使用することはできませんでした。 この新しい機能を検討する前に、InterSystems IRIS 内で非同期呼び出しがどのように機能するかを確認し、2 つの例を調べてみましょう。
従来の非同期呼び出し
これは従来のアプローチを示しています:
from iop import BusinessProcess from msg import MyMessage class MyBP(BusinessProcess): def on_message(self, request): msg_one = MyMessage(message="Message1") msg_two = MyMessage(message="Message2") self.send_request_async("Python.MyBO", msg_one, completion_key="1") self.send_request_async("Python.MyBO", msg_two, completion_key="2") def on_response(self, request, response, call_request, call_response, completion_key): if completion_key == "1": self.response_one = call_response elif completion_key == "2": self.response_two = call_response def on_complete(self, request, response): self.log_info(f"Received response one: {self.response_one.message}") self.log_info(f"Received response two: {self.response_two.message}")
これは、IRIS の非同期呼び出しの動作を反映しています。 send_request_async
はビジネス オペレーションにリクエストを送信し、on_response
は受け取ったレスポンスを処理します。 completion_key
は応答を区別します。
同期マルチリクエスト機能
まったく新しいわけではありませんが、複数の同期リクエストを同時に送信できる機能は注目に値します。
from iop import BusinessProcess from msg import MyMessage class MyMultiBP(BusinessProcess): def on_message(self, request): msg_one = MyMessage(message="Message1") msg_two = MyMessage(message="Message2") tuple_responses = self.send_multi_request_sync([("Python.MyMultiBO", msg_one), ("Python.MyMultiBO", msg_two)]) self.log_info("All requests have been processed") for target, request, response, status in tuple_responses: self.log_info(f"Received response: {response.message}")
この例では、2 つのリクエストを同じビジネス オペレーションに同時に送信します。応答は、各呼び出しのターゲット、要求、応答、ステータスを含むタプルです。これは、リクエストの順序が重要ではない場合に特に便利です。
非同期関数とコルーチン
IoP で非同期関数とコルーチンを活用する方法は次のとおりです。
import asyncio from iop import BusinessProcess from msg import MyMessage class MyAsyncNGBP(BusinessProcess): def on_message(self, request): results = asyncio.run(self.await_response(request)) for result in results: print(f"Received response: {result.message}") async def await_response(self, request): msg_one = MyMessage(message="Message1") msg_two = MyMessage(message="Message2") tasks = [self.send_request_async_ng("Python.MyAsyncNGBO", msg_one), self.send_request_async_ng("Python.MyAsyncNGBO", msg_two)] return await asyncio.gather(*tasks)
これは、send_request_async_ng
を使用して複数のリクエストを同時に送信します。 asyncio.gather
は、すべての応答が同時に待機されることを保証します。
ここまで読んでくださった方は「ブーメラン」にコメントをお願いします! それは大きな意味を持つでしょう。ありがとうございます!
await_response
は、複数のリクエストを送信し、すべての応答を待つコルーチンです。
非同期関数とコルーチンを使用する利点には、並列リクエストによるパフォーマンスの向上、可読性と保守性の向上、asyncio
モジュールを使用した柔軟性の向上、例外とタイムアウトの処理の向上が含まれます。
非同期メソッドの比較
send_request_async
、send_multi_request_sync
、send_request_async_ng
の主な違いは何ですか?
-
send_request_async
:on_response
が実装されており、completion_key
が使用されている場合にのみ、リクエストを送信し、応答を待ちます。 シンプルですが、並列リクエストのスケーラビリティは低くなります。 -
send_multi_request_sync
: 複数のリクエストを同時に送信し、すべての応答を待ちます。使い方は簡単ですが、応答順序は保証されません。 -
send_request_async_ng
: 複数のリクエストを同時に送信し、応答の順序を維持しながらすべての応答を待ちます。非同期関数とコルーチンが必要です。
マルチスレッドを楽しんでください!
以上がPython 更新の非同期サポートでの相互運用性の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

AlaySaregenerallymorememory-effictient forstring forstring inumericaldataduetotheirfixed-sizenature anddirectmoryaccess.1)AraysstoreElementsinaCourowlock、Reducingoverheadfrompointertersormetadata.2)リスト

ToconvertaPythonlisttoanarray,usethearraymodule:1)Importthearraymodule,2)Createalist,3)Usearray(typecode,list)toconvertit,specifyingthetypecodelike'i'forintegers.Thisconversionoptimizesmemoryusageforhomogeneousdata,enhancingperformanceinnumericalcomp

Pythonリストは、さまざまな種類のデータを保存できます。サンプルリストには、整数、文字列、フローティングポイント番号、ブール膜、ネストされたリスト、辞書が含まれています。リストの柔軟性は、データ処理とプロトタイピングにおいて価値がありますが、コードの読みやすさと保守性を確保するためには注意して使用する必要があります。

Pythondoesnothavebuiltinarays; usethearmoduleformemory-efficienthogeneousdatastorage、while-lelistSareversatileformixeddatypes.Arraysareeffientive for forlardatedateSetsetype、wheneasofferistofibuliestibuliestuseduseerieartusedoersorerdatatess。

sostCommonlylysedModule forcreatinginpythonisnumpy.1)numProvidesefficientToolsForArrayoperations、理想的なfornumericaldata.2)arrayscanbecreatedusingnp.array()for1dand2dstructures.3)

toAppendElementStoapyThonList、usetheappend()methodforsingleelements、extend()formultipleElements、andinsert()forspecificopsitions.1)useappend()foraddingoneElementatheend.2)useextend()toaddmultipleelementseffictience.3)

To CreateapythonList、usesquareBrackets []およびSeparateItemswithcommas.1)listsaredynamicandcanholdmixdatatypes.2)useappend()、remaid()、andslicingformanipulation.3)listcompreheNsionsionsionsionsionsionsionsionsionsionsionsionsionsionsionsionsionsientionforcreating.4)

金融、科学研究、医療、およびAIの分野では、数値データを効率的に保存および処理することが重要です。 1)財務では、メモリマッピングされたファイルとnumpyライブラリを使用すると、データ処理速度が大幅に向上する可能性があります。 2)科学研究の分野では、HDF5ファイルはデータストレージと取得用に最適化されています。 3)医療では、インデックス作成やパーティション化などのデータベース最適化テクノロジーがデータのパフォーマンスを向上させます。 4)AIでは、データシャーディングと分散トレーニングがモデルトレーニングを加速します。システムのパフォーマンスとスケーラビリティは、適切なツールとテクノロジーを選択し、ストレージと処理速度の間のトレードオフを検討することにより、大幅に改善できます。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

メモ帳++7.3.1
使いやすく無料のコードエディター

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、
