検索

Python のマルチスレッドの概要

Aug 23, 2017 am 11:44 AM
pythonthreadingはじめる

マルチスレッドは、複数のタスクを同時に実行することとして単純に理解できます。この記事では、Python マルチスレッドの初心者チュートリアルの例を詳しく説明します。興味のある友達は一緒に学ぶことができます

1.1 マルチスレッドとは簡単に言うと、複数のタスクを実行することです。同時。 マルチプロセスとマルチスレッドはどちらも複数のタスクを実行でき、スレッドはプロセスの一部です。スレッドの特徴は、スレッド間でメモリと変数を共有でき、リソースの消費が少ないことです (ただし、Unix 環境では、マルチプロセスとマルチスレッドのリソース スケジューリング消費量の差は明らかではなく、Unix のスケジューリングの方が高速です) ) 欠点は、スレッド間の同期と高速化がより面倒なことです。

1.2 スレッドの追加 Thread

モジュールのインポート

import threading

アクティブ化されたスレッドの数を取得


threading.active_count()

すべてのスレッド情報を表示


threading.enumerate()

今実行中です


rree

スレッドを追加します。

Receiveパラメータのターゲットは、このスレッドによって完了するタスクを表します。自分で定義する必要があります

threading.Thread()

threading.current_thread()


1.3結合関数

スレッドは同時に実行されているため、 join 関数を使用すると、スレッドを作成できます。 完了後、キュー内のすべてのタスクが処理されるまで呼び出しスレッドをブロックする次のステップに進みます。

def thread_job():
  print('This is a thread of %s' % threading.current_thread())
def main():
  thread = threading.Thread(target=thread_job,)  # 定义线程 
  thread.start() # 让线程开始工作
  if __name__ == '__main__':
  main()

上記の例は、join 関数が使用されていない場合、結果は次のようになります。


join 関数が実行されると、T1 の実行が終了した後にのみ T2 が実行されます。 1.4 保存処理結果キュー

キューは、Python 標準ライブラリのスレッドセーフ キュー (FIFO) 実装であり、適切な高度なメソッドを提供します。マルチスレッドプログラミングの場合、データ構造、つまりキューは、プロデューサースレッドとコンシューマースレッドの間で情報を転送するために使用されます

(1) 基本的な FIFO キュー

import threading
import time
def thread_job():
  print('T1 start\n')
  for i in range(10):
    time.sleep(0.1)
  print('T1 finish\n')
def T2_job():
  print('T2 start\n')
  print('T2 finish\n')
def main():
  added_thread=threading.Thread(target=thread_job,name='T1')
  thread2=threading.Thread(target=T2_job,name='T2')
  added_thread.start()
  #added_thread.join()
  thread2.start()
  #thread2.join()
  print('all done\n')
if __name__=='__main__':
   main()

maxsize はデータの数を示す整数です。上限に達すると、キュー内のデータが消費されるまで挿入がブロックされます。maxsize が 0 以下の場合、キューのサイズに制限はありません。 (2)LIFOキュー後入れ先出し

 class queue.Queue(maxsize=0)

(3)優先キュー


class queue.LifoQueue(maxsize=0)

動画内のコードは動画ではよく分かりません

class queue.PriorityQueue(maxsize=0)

実行結果は以下の通りです


1.5 GIL は必ずしも効率的ではありません

グローバル インタープリター ロック Python の実行は、Python 仮想マシン (インタープリター メイン ループとも呼ばれます) によって制御されます。仮想マシンでは、常に 1 つのスレッドだけがインタープリターで実行されるようにします。マルチスレッド環境では、Python 仮想マシンは次のように実行されます:

1. GIL を設定します

2. 実行するスレッドに切り替えます

3. バイトコード命令の数を指定します。または

b. スレッドが積極的に制御を放棄します (time.sleep(0) を呼び出すことができます)

5. GIL のロックを解除します
6. 前に 1 ~ 5 を繰り返します。外部コード (C/C++ 拡張関数など) を呼び出すと、GIL はこの関数が終了するまでロックされます (この期間中は Python バイトコードが実行されないため、スレッドの切り替えは実行されません)。

以下は、数値を4倍に拡張し、通常の方法に分割して4つのスレッドに割り当てているコード例です。実際には、消費時間はそれほど変わらないことがわかります。

import threading
import time
from queue import Queue
def job(l,q):
  for i in range(len(l)):
    l[i]=l[i]**2
  q.put(l)
def multithreading():
  q=Queue()
  threads=[]
  data=[[1,2,3],[3,4,5],[4,5,6],[5,6,7]]
  for i in range(4):
    t=threading.Thread(target=job,args=(data[i],q))
    t.start()
    threads.append(t)
  for thread in threads:
    thread.join()
  results=[]
  for _ in range(4):
    results.append(q.get())
  print(results)
if __name__=='__main__':
   multithreading()

実行結果は次のとおりです:

1.6 线程锁 Lock

如果线程1得到了结果,想要让线程2继续使用1的结果进行处理,则需要对1lock,等到1执行完,再开始执行线程2。一般来说对share memory即对共享内存进行加工处理时会用到lock。


import threading
def job1():
  global A, lock #全局变量
  lock.acquire() #开始lock
  for i in range(10):
    A += 1
    print('job1', A)
  lock.release() #释放
def job2(): 
  global A, lock
  lock.acquire()
  for i in range(10):
    A += 10
    print('job2', A)
  lock.release()
if __name__ == '__main__':
  lock = threading.Lock()
  A = 0
  t1 = threading.Thread(target=job1)
  t2 = threading.Thread(target=job2)
  t1.start()
  t2.start()
  t1.join()
  t2.join()

运行结果如下所示:

总结

以上がPython のマルチスレッドの概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Pythonを使用した科学コンピューティングでアレイはどのように使用されていますか?Pythonを使用した科学コンピューティングでアレイはどのように使用されていますか?Apr 25, 2025 am 12:28 AM

Arraysinpython、特にvianumpy、arecrucialinscientificComputing fortheirefficienty andversitility.1)彼らは、fornumericaloperations、data analysis、andmachinelearning.2)numpy'simplementation incensuresfasteroperationsthanpasteroperations.3)arayableminablecickick

同じシステムで異なるPythonバージョンをどのように処理しますか?同じシステムで異なるPythonバージョンをどのように処理しますか?Apr 25, 2025 am 12:24 AM

Pyenv、Venv、およびAnacondaを使用して、さまざまなPythonバージョンを管理できます。 1)Pyenvを使用して、複数のPythonバージョンを管理します。Pyenvをインストールし、グローバルバージョンとローカルバージョンを設定します。 2)VENVを使用して仮想環境を作成して、プロジェクトの依存関係を分離します。 3)Anacondaを使用して、データサイエンスプロジェクトでPythonバージョンを管理します。 4)システムレベルのタスク用にシステムPythonを保持します。これらのツールと戦略を通じて、Pythonのさまざまなバージョンを効果的に管理して、プロジェクトのスムーズな実行を確保できます。

標準のPythonアレイでnumpyアレイを使用することの利点は何ですか?標準のPythonアレイでnumpyアレイを使用することの利点は何ですか?Apr 25, 2025 am 12:21 AM

numpyarrayshaveveraladvantages-averstandardpythonarrays:1)thealmuchfasterduetocベースのインプレンテーション、2)アレモレメモリ効率、特にlargedatasets、および3)それらは、拡散化された、構造化された形成術科療法、

アレイの均質な性質はパフォーマンスにどのように影響しますか?アレイの均質な性質はパフォーマンスにどのように影響しますか?Apr 25, 2025 am 12:13 AM

パフォーマンスに対する配列の均一性の影響は二重です。1)均一性により、コンパイラはメモリアクセスを最適化し、パフォーマンスを改善できます。 2)しかし、タイプの多様性を制限し、それが非効率につながる可能性があります。要するに、適切なデータ構造を選択することが重要です。

実行可能なPythonスクリプトを作成するためのベストプラクティスは何ですか?実行可能なPythonスクリプトを作成するためのベストプラクティスは何ですか?Apr 25, 2025 am 12:11 AM

craftexecutablepythonscripts、次のようになります

numpyアレイは、アレイモジュールを使用して作成された配列とどのように異なりますか?numpyアレイは、アレイモジュールを使用して作成された配列とどのように異なりますか?Apr 24, 2025 pm 03:53 PM

numpyarraysarasarebetterfornumeroperations andmulti-dimensionaldata、whilethearraymoduleissuitable forbasic、1)numpyexcelsinperformance and forlargedatasentassandcomplexoperations.2)thearraymuremememory-effictientivearientfa

Numpyアレイの使用は、Pythonで配列モジュール配列の使用と比較してどのように比較されますか?Numpyアレイの使用は、Pythonで配列モジュール配列の使用と比較してどのように比較されますか?Apr 24, 2025 pm 03:49 PM

NumPyArraySareBetterforHeavyNumericalComputing、whilethearrayarayismoreSuitableformemory-constrainedprojectswithsimpledatatypes.1)numpyarraysofferarays andatiledance andpeperancedatasandatassandcomplexoperations.2)thearraymoduleisuleiseightweightandmemememe-ef

CTypesモジュールは、Pythonの配列にどのように関連していますか?CTypesモジュールは、Pythonの配列にどのように関連していますか?Apr 24, 2025 pm 03:45 PM

ctypesallowsinging andmanipulatingc-stylearraysinpython.1)usectypestointerfacewithclibrariesforperformance.2)createc-stylearraysfornumericalcomputations.3)passarraystocfunctions foreffientientoperations.how、how、becuutiousmorymanagemation、performanceo

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール