国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Pythonコンカレントフューチャーズ

Nov 04, 2024 am 04:13 AM

python concurrent.futures

未來(lái)

Future は、計(jì)算の結(jié)果または計(jì)算中に発生したエラーのいずれかを保持できるコンテナーです。 Future が作成されると、PENDING 狀態(tài)で開(kāi)始されます。ライブラリは、おそらくテスト目的を除いて、このオブジェクトが手動(dòng)で作成されることを意図していません。

import concurrent.futures as futures

f = futures.Future()
assert(f._result is None)
assert(f._exception is None)
assert(f._state == 'PENDING')

PENDING ステータスは、ユーザーによって要求された計(jì)算がスレッド プールに登録され、キューに配置されていますが、実行のためにまだどのスレッドにも取得されていないことを示します??栅攻欹氓嗓濠`からタスク (コールバック) を取得すると、Future は RUNNING 狀態(tài)に移行します。將來(lái)は PENDING 狀態(tài)にある場(chǎng)合にのみキャンセルできます。したがって、PENDING 狀態(tài)と RUNNING 狀態(tài)の間には、要求された計(jì)算をキャンセルできる時(shí)間枠があります。

import concurrent.futures as futures

def should_cancel_pending_future():
    f = futures.Future()
    assert(f._state == 'PENDING')
    assert(f.cancel())
    assert(f._state == 'CANCELLED')

def should_not_cancel_running_future():
    f = futures.Future()
    f.set_running_or_notify_cancel()
    assert(f._state == 'RUNNING')
    assert(not f.cancel())

def cancel_is_idempotent():
    f = futures.Future()
    assert(f.cancel())
    assert(f.cancel())


should_cancel_pending_future()
should_not_cancel_running_future()
cancel_is_idempotent()

スレッド プールで要求された操作は、計(jì)算された値で完了するか、エラーが発生する可能性があります。結(jié)果に関係なく、フューチャーは FINISHED 狀態(tài)に遷移します。結(jié)果またはエラーは、対応するフィールドに保存されます。

import concurrent.futures as futures

def future_completed_with_result():
    f = futures.Future()
    f.set_result('foo')
    assert(f._state == 'FINISHED')
    assert(f._result == 'foo')
    assert(f._exception is None)

def future_completed_with_exception():
    f = futures.Future()
    f.set_exception(NameError())
    assert(f._state == 'FINISHED')
    assert(f._result is None)
    assert(isinstance(f._exception, NameError))

future_completed_with_result()
future_completed_with_exception()

計(jì)算の結(jié)果を取得するには、result メソッドを使用します。計(jì)算がまだ完了していない場(chǎng)合、このメソッドは、計(jì)算が完了するか待機(jī)がタイムアウトになるまで、(結(jié)果が呼び出された) 現(xiàn)在のスレッドをブロックします。

計(jì)算がエラーなく正常に完了すると、result メソッドは計(jì)算された値を返します。

import concurrent.futures as futures
import time
import threading

f = futures.Future()
def target():
    time.sleep(1)
    f.set_result('foo')
threading.Thread(target=target).start()
assert(f.result() == 'foo')

計(jì)算中に例外が発生した場(chǎng)合、result はその例外を発生させます。

import concurrent.futures as futures
import time
import threading

f = futures.Future()
def target():
    time.sleep(1)
    f.set_exception(NameError)
threading.Thread(target=target).start()
try:
    f.result()
    raise Exception()
except NameError:
    assert(True)

待機(jī)中にメソッドがタイムアウトすると、TimeoutError が発生します。

import concurrent.futures as futures

f = futures.Future()
try:
    f.result(1)
    raise Exception()
except TimeoutError:
    assert(f._result is None)
    assert(f._exception is None)

キャンセルされた計(jì)算の結(jié)果を取得しようとすると、CancelledError が発生します。

import concurrent.futures as futures

f = futures.Future()
assert(f.cancel())
try:
    f.result()
    raise Exception()
except futures.CancelledError:
    assert(True)

待ち戦略

開(kāi)発プロセスでは、スレッド プールで N 回の計(jì)算を?qū)g行し、その完了を待つ必要があることがよくあります。これを?qū)g現(xiàn)するために、ライブラリは wait 関數(shù)を提供します。いくつかの待機(jī)戦略があります: FIRST_COMPLETED、FIRST_EXCEPTION、ALL_COMPLETED。

すべての待機(jī)戦略に共通するのは、wait メソッドに渡された先物がすでに完了している場(chǎng)合、選択された戦略に関係なく、渡された先物のコレクションが返されるということです。エラー、結(jié)果、キャンセルなど、どのように完了したかは関係ありません。

import concurrent.futures as futures

def test(return_when):
    f1, f2, f3 = futures.Future(), futures.Future(), futures.Future()
    f1.cancel()
    f1.set_running_or_notify_cancel() # required
    f2.set_result('foo')
    f3.set_exception(NameError)

    r = futures.wait([f1, f2, f3], return_when=return_when)
    assert(len(r.done) == 3)
    assert(len(r.not_done) == 0)

for return_when in [futures.ALL_COMPLETED, futures.FIRST_EXCEPTION, futures.FIRST_COMPLETED]:
    test(return_when)

ALL_COMPLETED 戦略

ALL_COMPLETED 戦略は、渡されたすべての Future の完了を待つこと、またはその時(shí)點(diǎn)までに完了した Future のコレクション (不完全な可能性があります) でタイムアウト後に終了することを保証します。

import concurrent.futures as futures

f = futures.Future()
assert(f._result is None)
assert(f._exception is None)
assert(f._state == 'PENDING')

FIRST_COMPLETED

FIRST_COMPLETED 戦略は、タイムアウトの場(chǎng)合に、少なくとも 1 つの完了したフューチャーを含むコレクション、または空のコレクションが返されることを保証します。 この戦略は、返されるコレクションに複數(shù)の要素を含めることができないことを意味するものではありません

import concurrent.futures as futures

def should_cancel_pending_future():
    f = futures.Future()
    assert(f._state == 'PENDING')
    assert(f.cancel())
    assert(f._state == 'CANCELLED')

def should_not_cancel_running_future():
    f = futures.Future()
    f.set_running_or_notify_cancel()
    assert(f._state == 'RUNNING')
    assert(not f.cancel())

def cancel_is_idempotent():
    f = futures.Future()
    assert(f.cancel())
    assert(f.cancel())


should_cancel_pending_future()
should_not_cancel_running_future()
cancel_is_idempotent()

FIRST_EXCEPTION

FIRST_EXCEPTION 戦略は、計(jì)算の 1 つがエラーで終了した場(chǎng)合に待機(jī)を中斷します。例外が発生しない場(chǎng)合、動(dòng)作は ALL_COMPLETED フューチャーと同じです。

import concurrent.futures as futures

def future_completed_with_result():
    f = futures.Future()
    f.set_result('foo')
    assert(f._state == 'FINISHED')
    assert(f._result == 'foo')
    assert(f._exception is None)

def future_completed_with_exception():
    f = futures.Future()
    f.set_exception(NameError())
    assert(f._state == 'FINISHED')
    assert(f._result is None)
    assert(isinstance(f._exception, NameError))

future_completed_with_result()
future_completed_with_exception()

スレッドプールエグゼキュータ

オブジェクトはスレッド プールの作成を擔(dān)當(dāng)します。このオブジェクトと対話するための主なメソッドは、Submit メソッドです。スレッドプールに計(jì)算を登録できます。応答として、Future オブジェクトが返されます。これは、計(jì)算のステータスを監(jiān)視し、最終結(jié)果を取得するために使用されます。

プロパティ

  • 新しいスレッドは必要な場(chǎng)合にのみ作成されます。
    • 計(jì)算が要求されたときに少なくとも 1 つの空きスレッドがある場(chǎng)合、新しいスレッドは作成されません
    • 計(jì)算がリクエストされたときに空きスレッドがない場(chǎng)合は、maxWorkers 制限に達(dá)していない限り、新しいスレッドが作成されます。
    • 空きスレッドがなく、maxWorkers の制限に達(dá)した場(chǎng)合、計(jì)算はキューに入れられ、次に利用可能なスレッドが処理します
  • デフォルトでは、計(jì)算ニーズに割り當(dāng)てられるスレッドの最大數(shù)は、論理プロセッサ コアの數(shù)と等しくなります
  • スレッドは一度作成されると、負(fù)荷が低い場(chǎng)合でも破棄されません

以上がPythonコンカレントフューチャーズの詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見(jiàn)つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫(huà)像を無(wú)料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫(xiě)真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫(xiě)真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類(lèi)リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開(kāi)発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開(kāi)発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

PythonでAPI認(rèn)証を処理する方法 PythonでAPI認(rèn)証を処理する方法 Jul 13, 2025 am 02:22 AM

API認(rèn)証を扱うための鍵は、認(rèn)証方法を正しく理解して使用することです。 1。Apikeyは、通常、リクエストヘッダーまたはURLパラメーターに配置されている最も単純な認(rèn)証方法です。 2。BasicAuthは、內(nèi)部システムに適したBase64エンコード送信にユーザー名とパスワードを使用します。 3。OAUTH2は、最初にclient_idとclient_secretを介してトークンを取得し、次にリクエストヘッダーにbearertokenを持ち込む必要があります。 4。トークンの有効期限に対処するために、トークン管理クラスをカプセル化し、トークンを自動(dòng)的に更新できます。要するに、文書(shū)に従って適切な方法を選択し、重要な情報(bào)を安全に保存することが重要です。

Pythonの主張を説明します。 Pythonの主張を説明します。 Jul 07, 2025 am 12:14 AM

Assertは、Pythonでデバッグに使用されるアサーションツールであり、條件が満たされないときにアサーションエラーを投げます。その構(gòu)文は、アサート條件とオプションのエラー情報(bào)であり、パラメーターチェック、ステータス確認(rèn)などの內(nèi)部ロジック検証に適していますが、セキュリティまたはユーザーの入力チェックには使用できず、明確な迅速な情報(bào)と組み合わせて使用??する必要があります。例外処理を置き換えるのではなく、開(kāi)発段階での補(bǔ)助デバッグにのみ利用できます。

Pythonタイプのヒントとは何ですか? Pythonタイプのヒントとは何ですか? Jul 07, 2025 am 02:55 AM

タイプヒントシンパソコンの問(wèn)題と、ポテンシャルを使用して、dynamivitytedcodedededevelowingdeexpecifeedtypes.theyenhanceReadeadability、inableearlybugdetection、およびrequrovetoolingsusingsupport.typehintsareadddeduneadddedusingolon(:)

一度に2つのリストを繰り返す方法Python 一度に2つのリストを繰り返す方法Python Jul 09, 2025 am 01:13 AM

Pythonで2つのリストを同時(shí)にトラバースする一般的な方法は、Zip()関數(shù)を使用することです。これは、複數(shù)のリストを順?lè)衰讠ⅴ辚螗挨?、最短になります。リストの長(zhǎng)さが一貫していない場(chǎng)合は、itertools.zip_longest()を使用して最長(zhǎng)になり、欠損値を入力できます。 enumerate()と組み合わせて、同時(shí)にインデックスを取得できます。 1.Zip()は簡(jiǎn)潔で実用的で、ペアのデータ反復(fù)に適しています。 2.zip_longest()は、一貫性のない長(zhǎng)さを扱うときにデフォルト値を入力できます。 3. Enumerate(Zip())は、トラバーサル中にインデックスを取得し、さまざまな複雑なシナリオのニーズを満たすことができます。

Python Iteratorsとは何ですか? Python Iteratorsとは何ですか? Jul 08, 2025 am 02:56 AM

inpython、iteratoratorSareObjectsthatallopingthroughcollectionsbyimplementing __()and__next __()

Python Fastapiチュートリアル Python Fastapiチュートリアル Jul 12, 2025 am 02:42 AM

Pythonを使用して最新の効率的なAPIを作成するには、Fastapiをお?jiǎng)幛幛筏蓼?。?biāo)準(zhǔn)のPythonタイプのプロンプトに基づいており、優(yōu)れたパフォーマンスでドキュメントを自動(dòng)的に生成できます。 FastAPIおよびASGIサーバーUVICORNをインストールした後、インターフェイスコードを記述できます。ルートを定義し、処理機(jī)能を作成し、データを返すことにより、APIをすばやく構(gòu)築できます。 Fastapiは、さまざまなHTTPメソッドをサポートし、自動(dòng)的に生成されたSwaggeruiおよびRedocドキュメントシステムを提供します。 URLパラメーターはパス定義を介してキャプチャできますが、クエリパラメーターは、関數(shù)パラメーターのデフォルト値を設(shè)定することで実裝できます。 Pydanticモデルの合理的な使用は、開(kāi)発の効率と精度を改善するのに役立ちます。

PythonでAPIをテストする方法 PythonでAPIをテストする方法 Jul 12, 2025 am 02:47 AM

APIをテストするには、Pythonのリクエストライブラリを使用する必要があります。手順は、ライブラリのインストール、リクエストの送信、応答の確認(rèn)、タイムアウトの設(shè)定、再試行です。まず、pipinstallRequestsを介してライブラリをインストールします。次に、requests.get()またはrequests.post()およびその他のメソッドを使用して、get requestsを送信または投稿します。次に、respons.status_codeとresponse.json()を確認(rèn)して、返品結(jié)果が期待に準(zhǔn)拠していることを確認(rèn)します。最後に、タイムアウトパラメーターを追加してタイムアウト時(shí)間を設(shè)定し、再試行ライブラリを組み合わせて自動(dòng)再生を?qū)g現(xiàn)して安定性を高めます。

関數(shù)のPython変數(shù)スコープ 関數(shù)のPython変數(shù)スコープ Jul 12, 2025 am 02:49 AM

Pythonでは、関數(shù)內(nèi)で定義されている変數(shù)はローカル変數(shù)であり、関數(shù)內(nèi)でのみ有効です。外部から定義されているのは、どこでも読むことができるグローバル変數(shù)です。 1。関數(shù)が実行されると、ローカル変數(shù)が破壊されます。 2。関數(shù)はグローバル変數(shù)にアクセスできますが、直接変更できないため、グローバルキーワードが必要です。 3.ネストされた関數(shù)で外部関數(shù)変數(shù)を変更する場(chǎng)合は、非ローカルキーワードを使用する必要があります。 4。同じ名前の変數(shù)は、異なるスコープで互いに影響を與えません。 5。グローバル変數(shù)を変更するときにグローバルを宣言する必要があります。それ以外の場(chǎng)合は、バウンドロカレラーロールエラーが発生します。これらのルールを理解することで、バグを回避し、より信頼性の高い機(jī)能を書(shū)くことができます。

See all articles