ホームページ  >  記事  >  Java  >  Javaのスレッドプール

Javaのスレッドプール

WBOY
WBOYオリジナル
2023-06-15 20:51:481398ブラウズ

Java では、スレッド プールは、スレッドの作成、保守、破棄などのタスクを管理するために使用されます。スレッド プールには、スレッドのグループとタスク キューが含まれています。タスクを実行する必要がある場合、スレッド プール内のスレッドは自動的にタスクを取得して実行します。タスクの実行後、スレッドもスレッドにリサイクルされます。再利用のためのスレッド プール。

Java のスレッド プール API は、スレッド プールの作成に役立つ Executors クラスを提供し、FixedThreadPool、CachedThreadPool、SingleThreadExecutor、および ScheduledThreadPool という 4 つのスレッド プール実装メソッドを提供します。

FixedThreadPool

固定サイズのスレッド プールは、作業スレッドの数がスレッド プールのサイズに達しない場合にのみ、タスクを実行するための新しいスレッドを作成します。スレッド プールはコンストラクターを介してスレッドの最大数を指定できます。指定しない場合は、デフォルトで Integer.MAX_VALUE になります。

サンプルコード:

ExecutorService executorService = Executors.newFixedThreadPool(5);
for (int i = 0; i < 10; i++) {
    executorService.execute(()->{
        System.out.println(Thread.currentThread().getName()+" is executing task ");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    });
}

実行結果:

pool-1-thread-1 is executing task 
pool-1-thread-3 is executing task 
pool-1-thread-5 is executing task 
pool-1-thread-2 is executing task 
pool-1-thread-4 is executing task 
pool-1-thread-5 is executing task 
pool-1-thread-3 is executing task 
pool-1-thread-1 is executing task 
pool-1-thread-2 is executing task 
pool-1-thread-4 is executing task 

CachedThreadPool

キャッシュ可能なスレッドプール、スレッド数が現在必要な数を超えた場合、超過スレッドスレッド プールにリサイクルされ、不要になった場合は自動的に破棄されます。スレッド プールに使用可能なスレッドがなく、新しいタスクが到着した場合、スレッド プールのサイズが Integer.MAX_VALUE の制限に達するまで、スレッド プールは新しいスレッドを作成してタスクを実行します。

サンプル コード:

ExecutorService executorService = Executors.newCachedThreadPool();
for (int i = 0; i < 10; i++) {
    executorService.execute(()->{
        System.out.println(Thread.currentThread().getName()+" is executing task ");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    });
}

実行結果:

pool-1-thread-1 is executing task 
pool-1-thread-2 is executing task 
pool-1-thread-3 is executing task 
pool-1-thread-4 is executing task 
pool-1-thread-5 is executing task 
pool-1-thread-6 is executing task 
pool-1-thread-7 is executing task 
pool-1-thread-8 is executing task 
pool-1-thread-9 is executing task 
pool-1-thread-10 is executing task 

SingleThreadExecutor

ワーカー スレッドが 1 つだけあるシングル スレッド スレッド プールにより、すべてのタスクが確実に実行されます。指定どおりに実行されます。 特別なFixedThreadPoolと同等の順序(FIFO、LIFO、優先順位など)で実行されます。

サンプル コード:

ExecutorService executorService = Executors.newSingleThreadExecutor();
for (int i = 0; i < 10; i++) {
    executorService.execute(()->{
        System.out.println(Thread.currentThread().getName()+" is executing task ");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    });
}

実行結果:

pool-1-thread-1 is executing task 
pool-1-thread-1 is executing task 
pool-1-thread-1 is executing task
......

ScheduledThreadPool

定期的にスケジュールされたスレッド プールは、指定された遅延時間に従って、または定期的にスケジュールできます。タスクを実行するには、スケジュールされたタスクまたは定期的なタスクを実装できます。スレッド プールのサイズを指定できます。指定しない場合は、デフォルトで Integer.MAX_VALUE が使用されます。

サンプル コード:

ScheduledExecutorService scheduledExecutorService = Executors.newScheduledThreadPool(3);
ScheduledFuture<?> future = scheduledExecutorService.schedule(()->{
    System.out.println(Thread.currentThread().getName()+" is executing delay task ");
}, 5, TimeUnit.SECONDS);
scheduledExecutorService.scheduleAtFixedRate(()->{
    System.out.println(Thread.currentThread().getName()+" is executing periodic task ");
}, 2, 3, TimeUnit.SECONDS);

実行結果:

pool-1-thread-1 is executing periodic task 
pool-1-thread-2 is executing periodic task 
pool-1-thread-3 is executing periodic task 
pool-1-thread-1 is executing periodic task 
pool-1-thread-3 is executing periodic task 
pool-1-thread-2 is executing periodic task 
pool-1-thread-3 is executing periodic task 
pool-1-thread-2 is executing periodic task 
......
pool-1-thread-1 is executing delay task 

概要

スレッド プールはマルチスレッド開発において非常に重要な概念であり、効果的にスレッドを削減できます。作成、破棄、コンテキストの切り替え、その他のオーバーヘッドを軽減し、システムのパフォーマンスと保守性を向上させます。 Java は、スレッド プールを簡単に作成するための Executors クラスを提供し、さまざまなアプリケーション シナリオに対処するためのさまざまな実装メソッドを提供します。開発者がスレッド プールを使用する場合、最高のパフォーマンスと効果を達成するには、特定のニーズと負荷条件に基づいて適切な実装方法を選択する必要があります。

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

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。