この記事では、Python スレッド ロックとは何かを見てみましょう。 Python のスレッド ロックと、Python プログラミングにおいてスレッド ロックが果たせる役割について学びます。
スレッド ロック (ミューテックス)
1 つのプロセスの下で複数のスレッドを開始でき、複数のスレッドが親プロセスのメモリ空間を共有します。つまり、それぞれ 2 つのスレッドがこのとき、2 つのスレッドが同じデータを同時に変更したい場合はどうなりますか?
ロックの使用:
ロックの作成
mutex = threading.Lock()
Lock
mutex.acquire([timeout ])
Release
mutex.release()
import time import threading def addNum(): global num #在每个线程中都获取这个全局变量 print('--get num:',num ) time.sleep(1) num -=1 #对此公共变量进行-1操作 num = 100 #设定一个共享变量 thread_list = [] for i in range(100): t = threading.Thread(target=addNum) t.start() thread_list.append(t) for t in thread_list: #等待所有线程执行完毕 t.join() print('final num:', num )
通常、この num の結果は 0 になるはずですが、Python 2.7 で数回実行すると、最終的な出力結果が常に 0 であるとは限りません。実行するたびに結果が異なるのはなぜですか?はは、とても簡単です。2 つのスレッド A と B があるとします。このとき、num を 1 減らす必要があります。2 つのスレッドは同時に実行されているため、最初の時点で 2 つのスレッドによって num=100 が奪われてしまう可能性が非常に高いです。この初期変数は計算のために CPU に渡されます。スレッド A が計算を完了すると、結果は 99 になりますが、この時点ではスレッド B が計算を完了し、結果も 99 になります。CPU の結果の後2 つのスレッドの同時計算が num 変数に割り当てられると、結果は両方とも 99 になります。それではどうすればいいでしょうか?それはとても簡単です。各スレッドが公開データを変更したいとき、変更が完了する前に他のスレッドがデータを変更できないようにするために、データにロックを追加して、他のスレッドがデータを変更したいときに待機する必要があるようにすることができます。このデータに再度アクセスできるのは、変更を完了してロックを解除した後のみです。
#注: 3.x では実行しないでください。何らかの理由で、3.x での結果は常に正しいです。ロックが自動的に追加される可能性があります。
以上です この記事で解説する内容は、主にpython mutex lock に関する知識を中心に紹介していますので、上記の内容を理解するために活用していただければ幸いです。この記事で説明したことがあなたのお役に立ち、Python の学習が容易になることを願っています。
関連知識の詳細については、php 中国語 Web サイトのPython チュートリアル 列を参照してください。
以上がPythonスレッドロックの使い方(解析例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Pythonリストスライスの基本的な構文はリストです[start:stop:step]。 1.STARTは最初の要素インデックス、2。ストップは除外された最初の要素インデックスであり、3.ステップは要素間のステップサイズを決定します。スライスは、データを抽出するためだけでなく、リストを変更および反転させるためにも使用されます。

ListSoutPerformArraysIn:1)ダイナミシジョンアンドフレーケンティオン/削除、2)ストーリングヘテロゼンダタ、および3)メモリ効率の装飾、ButmayhaveslightPerformancostsinceNASOPERATIONS。

toconvertapythonarraytoalist、usetheList()constructororageneratorexpression.1)importhearraymoduleandcreateanarray.2)useList(arr)または[xforxinarr] toconvertoalistは、largedatatessを変えることを伴うものです。

choosearraysoverlistsinperbetterperformance andmemoryeficiencyspecificscenarios.1)largeNumericaldatasets:Araysreducememoryusage.2)パフォーマンス - クリティカル操作:ArraysOfferSpeedBoostsfortsfortsclikeappendedoring.3)タイプリー:Arrayesenforc

Pythonでは、ループに使用し、列挙し、包括的なリストを通過することができます。 Javaでは、従来のループを使用し、ループを強化してアレイを通過することができます。 1。Pythonリストトラバーサル方法は、ループ、列挙、およびリスト理解のためのものです。 2。Javaアレイトラバーサル法には、従来のループとループ用の強化が含まれます。

この記事では、バージョン3.10で導入されたPythonの新しい「マッチ」ステートメントについて説明します。これは、他の言語のスイッチステートメントに相当するものです。コードの読みやすさを向上させ、従来のif-elif-elよりもパフォーマンスの利点を提供します

Python 3.11の例外グループは、複数の例外を同時に処理することで、同時シナリオと複雑な操作でエラー管理を改善します。

Pythonの関数注釈は、タイプチェック、ドキュメント、およびIDEサポートの関数にメタデータを追加します。それらはコードの読みやすさ、メンテナンスを強化し、API開発、データサイエンス、ライブラリの作成において重要です。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ドリームウィーバー CS6
ビジュアル Web 開発ツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ホットトピック









