ホームページ >Java >&#&チュートリアル >Java でスレッドを同期する方法: アプリケーション ロジック スレッドはデータベース スレッドの初期化が完了するまでどのように待機できますか?
Java でのスレッド出力の待機
Java アプリケーションの開発では、複数のスレッドを同時に実行することがよくあるため、適切なフローとデータの同期を確保するための調整メカニズムが必要です。この記事では、あるスレッドが別のスレッドの出力を待機する必要がある特定のシナリオについて説明します。
この場合、アプリケーションは、アプリケーション ロジック スレッドとデータベース アクセス スレッドの 2 つのスレッドを使用します。両方のスレッドはアプリケーションの存続期間中存続し、同時に動作する必要がありますが、アプリケーション ロジック スレッドは最初、データベース アクセス スレッドの準備ができるまで待機する必要があります。
考えられる解決策
質問適切な解決策を見つける際に課題が生じます。データベース スレッドはアプリケーションのシャットダウン中にのみ終了するため、Thread.join() の使用はオプションではありません。さらに、データベースの準備状況をポーリングする空のループを作成すると、不要な CPU 消費が発生します。
CountDownLatch アプローチ
推奨されるソリューションでは、カウンター メカニズムを使用する CountDownLatch クラスを利用します。 。カウンタは 1 に初期化され、完了するために必要な 1 つの操作を表します。
アプリケーション スレッドの実行
アプリケーション ロジック スレッドのコードには次のものが含まれます。
CountDownLatch latch = new CountDownLatch(1); latch.await();
latch.await() メソッドは、ラッチ カウンタが 0 に達し、データベースの初期化の完了を通知するまで、それ以降の実行をブロックします。
データベース スレッドの実行
1 回データベース スレッドは初期化を完了すると、以下を実行します。
latch.countDown();
ラッチ カウンターをデクリメントすると、アプリ スレッドの待機が解放されます。
このアプローチにより、2 つのスレッドが効果的に同期され、アプリケーション ロジック スレッドが確実に処理を続行できるようになります。データベーススレッドの準備ができた後にのみ。これは、スレッド調整のための効率的で非ブロッキングなメカニズムを提供し、ループのブロックやデータベース スレッドの中断による欠点を回避します。
以上がJava でスレッドを同期する方法: アプリケーション ロジック スレッドはデータベース スレッドの初期化が完了するまでどのように待機できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。