Python での並列プログラミング: 並列処理の課題に対する解決策
並列プログラミングは、複数のタスクを同時に実行することでパフォーマンスを向上させることを目的としています。 Python では、C で一般的に使用される OpenMP はすぐには適用できません。この記事では、Python プログラムでの並列処理の実装の問題について取り上げ、独立した関数を同時に実行するという課題に取り組みます。
指定されたコード構造:
solve1(A) solve2(B)
では、コード内の独立した関数を識別する必要があります。この例では、solve1 とsolve2 は 2 つの別個の関数です。
このコードを並列化するには、プロセスベースの並列処理を可能にする Python のマルチプロセッシング モジュールの使用を検討してください。特定のシナリオでは、処理プールを利用できます。
<code class="python">from multiprocessing import Pool pool = Pool() result1 = pool.apply_async(solve1, [A]) # evaluate "solve1(A)" asynchronously result2 = pool.apply_async(solve2, [B]) # evaluate "solve2(B)" asynchronously answer1 = result1.get(timeout=10) answer2 = result2.get(timeout=10)</code>
このアプローチでは、CPU コアごとに 1 つずつ複数のプロセスを利用して、独立した機能を同時に実行します。この分業により、プログラムの実行時間が短縮される可能性があります。
リストを 1 つの関数にマッピングするための別のオプションは次のとおりです。
<code class="python">args = [A, B] results = pool.map(solve1, args)</code>
スレッドを次のようにマッピングすべきではないことに注意することが重要です。 GIL (グローバル インタープリター ロック) により、複数のスレッドが Python コードを同時に実行できなくなり、並列実行が無効になるため、Python の並列処理に使用されます。
以上がPython プログラムで並列処理を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。