マルチスレッド操作の調整: Java でのデータ整合性の確保
マルチスレッド アプリケーションを操作する場合、すべてのスレッドが処理を完了していることを確認することが不可欠です。共有データに対して重要な操作を実行する前にタスクを実行します。あなたの場合、5 つのスレッドが同時に Web からデータを取得し、バッファー クラス内のフィールドにデータを設定します。完全なバッファ データを検証してデータベースに保存するには、すべてのスレッドが作業を終了したときに通知を受けるメカニズムが必要です。
スレッド プールの管理に推奨されるアプローチは、ExecutorService を使用することです。スレッドの作成と管理のプロセス。これを Java で実装する方法は次のとおりです。
// Create an ExecutorService to manage the thread pool ExecutorService es = Executors.newCachedThreadPool(); // Launch the individual tasks using execute() for(int i=0; i<5; i++) { es.execute(new Runnable() { /* Your task definition here */ }); } // Shutdown the ExecutorService to prevent new tasks from being submitted es.shutdown(); // Wait for the tasks to complete using awaitTermination() try { boolean finished = es.awaitTermination(1, TimeUnit.MINUTES); // The tasks have finished or the timeout has been reached } catch(InterruptedException e) { // Handle the interruption scenario }
ExecutorService を利用すると、すべてのタスクが指定された時間枠内に作業を完了していることを効率的に確認できます。 awaitTermination() メソッドが完了を示したら、自信を持ってバッファ データの検証とデータベースへの保存を続行できます。
以上がマルチスレッド Java アプリケーションでデータベース操作の前にすべてのスレッドが確実に終了するようにするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。