Javaの今後のパターン
jdk1.7.0_79
この記事は実は上記の「13.ThreadPoolExecutorsubmitメソッドのスレッドプール」の続編というか補足になります。 FutureTaskは、前述のsubmitメソッドに出現しましたが、これを停止して、JavaのFutureモードに方向を変える必要がありました。
Future は、マルチスレッドの場合、スレッド B の結果を待つ必要があります。 、最初に未来 Future を取得し、B が結果を取得した後に実際の結果を取得することができます。 ExecutorService executor = Executors.newSingleThreadExecutor();
Future<String> future = executor.submit(callable); //主线程需要callable线程的结果,先拿到一个未来的FutureSystem.out.println(future.get()); //有了结果后再根据get方法取真实的结果,当然如果此时callable线程如果没有执行完get方法会阻塞执行完,如果执行完则直接返回结果或抛出异常
上記はFuture
モードの実行原理を表しています。オンラインの例によれば、Future
モードを自分で実装できます。 1 package com.future;2 3 /**4 * 数据结果5 * Created by yulinfeng on 6/18/17.6 */7 public interface Data {8 String getResult() throws InterruptedException;9 }
1 package com.future; 2 3 /** 4 * 结果的真实计算过程 5 * Created by yulinfeng on 6/18/17. 6 */ 7 public class RealData implements Data { 8 protected String data; 9 10 public RealData(String data) {11 try {12 System.out.println("正在计算结果");13 Thread.sleep(3000); //模拟计算14 } catch (InterruptedException e) {15 e.printStackTrace();16 }17 this.data = data + “ world”;18 }19 20 public String getResult() throws InterruptedException {21 return data;22 }23 }
1 package com.future; 2 3 /** 4 * 真实结果RealData的代理 5 * Created by yulinfeng on 6/18/17. 6 */ 7 public class FutureData implements Data { 8 RealData realData = null; //对RealData的封装,代理了RealData 9 boolean isReady = false; //真实结果是否已经准备好10 11 public synchronized void setResultData(RealData realData) {12 if (isReady) {13 return;14 }15 this.realData = realData;16 isReady = true;17 notifyAll(); //realData已经被注入到了futureData中,通知getResult方法18 }19 20 public synchronized String getResult() throws InterruptedException {21 if (!isReady) {22 wait(); //数据还未计算好,阻塞等待23 }24 return realData.getResult();25 }26 }
1 package com.future; 2 3 /** 4 * Client主要完成的功能包括:1. 返回一个FutureData;2.开启一个线程用于构造RealData 5 * Created by yulinfeng on 6/18/17. 6 */ 7 public class Client { 8 9 public Data request(final String string) {10 final FutureData futureData = new FutureData();11 12 /*计算过程比较慢,单独放到一个线程中去*/13 new Thread(new Runnable() {14 15 public void run() {16 RealData realData = new RealData(string);17 futureData.setResultData(realData);18 }19 }).start();20 21 return futureData; //先返回一个“假”的futureData22 }23 }
1 /** 2 * 负责调用Client发起请求,并使用返回的数据。 3 * Created by yulinfeng on 6/18/17. 4 */ 5 public class Main { 6 public static void main(String[] args) throws InterruptedException { 7 Client client = new Client(); 8 System.out.println("准备计算结果"); 9 Data data = client.request("hello"); //立即返回一个“假”的futureData,可以不用阻塞的等待数据返回,转而执行其它任务10 System.out.println("执行其它任务");11 Thread.sleep(3000); //模拟执行其它任务12 System.out.println("数据的计算结果为:" + data.getResult());13 }14 }
がパターンはです非同期リクエストとプロキシ パターンを組み合わせます。もちろん、FutureモードはJDKに実装されています。 RealData クラスを変更します:
1 package com.future; 2 3 import java.util.concurrent.Callable; 4 5 /** 6 * 结果的真实计算过程 7 * Created by yulinfeng on 6/18/17. 8 */ 9 public class RealData2 implements Callable<String> {10 protected String data;11 12 public RealData2(String data) {13 this.data = data;14 }15 public String call() throws Exception {16 try {17 System.out.println("正在计算结果");18 Thread.sleep(2000); //模拟计算结果19 } catch (InterruptedException e) {20 e.printStackTrace();21 }22 this.data = data + " world";23 return data;24 }25 }
MainTest クラスを変更します:
1 package com.future; 2 3 import java.util.concurrent.ExecutionException; 4 import java.util.concurrent.ExecutorService; 5 import java.util.concurrent.Executors; 6 import java.util.concurrent.Future; 7 8 /** 9 * 负责调用Executor的submit,并使用返回的数据。10 * Created by yulinfeng on 6/18/17.11 */12 public class Main2 {13 14 public static void main(String[] args) throws InterruptedException, ExecutionException {15 ExecutorService client = Executors.newSingleThreadExecutor(); //类似Client16 System.out.println("准备计算结果");17 Future<String> data = client.submit(new RealData2("hello")); //类似Client.request18 System.out.println("执行其它任务");19 Thread.sleep(3000);20 System.out.println("数据的计算结果为:" + data.get());21 }22 }
现在回到上文还未解决完的AbstractExecutorService#submit方法。
类比上面的Client#request方法,在Client#request中先创建一个FutureData实例,而在AbstractExecutorService#submit中则是创建一个FutureTask实例,接着Client#request新创建一个线程用于异步执行任务,并直接返回FutureData,而在AbstractExecutorService#submit中同样也将任务交给了execute方法,并直接返回FutureTask。当然JDK中Future模式的实现更为复杂。
在《12.ThreadPoolExecutor线程池原理及其execute方法》中我们讲解了execute方法,在ThreadPoolExecutor$Worker#runWorker方法第1145行中是对task任务的调用:
//ThreadPoolExecutor$Worker#runWorkertask.run();
submit调用execute以执行run方法,实际执行的是FutureTask中的run方法。在FutureTask#run中,可以看到对任务Callable类型的task异步的执行,以及结果的保存。
以上がJavaの今後のパターンの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

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

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

ホットトピック









WeChat のサイレント モードとはどういう意味ですか? 現在、スマートフォンの人気とモバイル インターネットの急速な発展により、ソーシャル メディア プラットフォームは人々の日常生活に欠かせないものとなっています。 WeChat は中国で最も人気のあるソーシャル メディア プラットフォームの 1 つであり、ほとんどの人が WeChat アカウントを持っています。私たちは WeChat を通じて友人、家族、同僚とリアルタイムでコミュニケーションを取り、生活の瞬間を共有し、お互いの現在の状況を理解することができます。しかし、この時代では、特に集中力や集中力が必要な人々にとって、情報過多やプライバシー漏洩の問題にも必然的に直面します。

iOS デバイスでは、ヘルスケア アプリを使用して睡眠パターンなどを追跡できるようになってきました。でも、寝ているときに通知が来ると煩わしくありませんか?これらの通知は無関係である可能性があるため、その過程で睡眠パターンが混乱します。おやすみモードは、睡眠中に気を散らすのを避けるための優れた方法ですが、夜間に受信する重要な電話やメッセージを見逃す可能性があります。ありがたいことに、ここでスリープモードが登場します。それについてさらに詳しく、そしてiPhoneでそれを使用する方法を学びましょう。 iPhone ではスリープ モードはどのような役割を果たしますか? スリープ モードは iOS 専用のフォーカス モードで、「ヘルスケア」アプリの睡眠スケジュールに基づいて自動的に有効になります。アラームを設定するのに役立ちます。

epc+o モデルとは、設計、調達などを統合した総合請負の枠組みを指します。これは、epc から派生した一部の運用上のリンクであり、建設期間中、ゼネコンは従来の意味での設計業務を請け負うだけでなく、さらに、運用期間中はすべてのメンテナンス作業も実行する必要があります。このモデルは、多くのプロジェクトの運用効率を大幅に向上させ、運用コストを迅速に削減できます。

おやすみモードで電話に応答することさえ、非常に煩わしい経験になる可能性があります。名前が示すように、おやすみモードでは、すべての着信通知と電子メール、メッセージなどからの警告がオフになります。これらのソリューション セットに従って問題を修正できます。解決策 1 – フォーカス モードを有効にする 携帯電話でフォーカス モードを有効にします。ステップ 1 – 上から下にスワイプしてコントロール センターにアクセスします。ステップ 2 – 次に、携帯電話の「フォーカスモード」を有効にします。フォーカス モードでは、電話機のサイレント モードが有効になります。携帯電話に着信通知が表示されることはありません。解決策 2 – フォーカス モード設定を変更する フォーカス モード設定に問題がある場合は、修正する必要があります。ステップ 1 – iPhone の設定ウィンドウを開きます。ステップ 2 – 次に、フォーカス モード設定をオンにします

iPhone 15 Pro および iPhone 15 Pro Max モデルで、Apple は、音量ボタンの上にある従来の着信音/サイレント スイッチに代わる、物理的にプログラム可能なアクション ボタンを導入しました。アクション ボタンは、いくつかの異なる機能を実行するようにプログラムできますが、サイレント モードと着信モードを切り替える機能はなくなっていません。デフォルトでは、アクション ボタンを長押しするとデバイスが沈黙し、ボタンの触覚フィードバックが 3 回脈動します。どちらの iPhone 15 Pro モデルでも、ステータス バーの時刻の横に取り消し線のベル記号が表示され、サイレント/サイレント モードが有効になっていることを示します。また、アクション ボタンを再度長押ししてデバイスのミュートを解除するまで、この状態が維持されます。 iPhoneをマナーモードにしたい場合

S モードの Windows は、Microsoft Store からのアプリのインストールのみを許可することで、セキュリティとパフォーマンスが強化されるように設計されています。この機能はマルウェアを防止し、安全なコンピューティング環境を確保するのに役立ちますが、Microsoft Store 以外のソースからアプリケーションをインストールしたいユーザーが制限される可能性があります。このような状況に陥り、Windows 10/11 で S モードから切り替える方法を自問し続けている場合は、2 つの異なるモードを使用して Windows 10/11 で S モードから切り替える方法を説明するので、ここは正しい場所に来ています。 S モードに移行すると、どこからでもアプリを自由にインストールできるようになります。 Windows で S モードを終了する方法を学習します。

iOS17 ではスタンバイ モードが iPhone に導入されます。このガイドは、iPhone でこの機能を使用する方法を示すことを目的としています。スタンバイ モードは、iPhone をダイナミックな常時オンのスマート ディスプレイに変える画期的な機能です。充電中にiPhoneを横向きに置くとスタンバイモードになります。このモードでは、現在時刻、地域の天気予報、お気に入りの写真のスライドショー、さらには音楽再生コントロールなど、さまざまな便利なウィジェットが美しく表示されます。このモードの大きな利点は、通知を表示できることであり、ユーザーは iPhone を完全に起動しなくても通知を表示して操作できるようになります。スタンバイ モードの使用方法 スタンバイ モードが適切に機能するには、iPhone が実行されている必要があります。

Notepad++ ダーク モード v8.0 にはパラメータがありません。Notepad++ は最も便利なテキスト エディタです。 Windows 10 で実行されるすべてのアプリはダーク モードをサポートしています。 Chrome、Firefox、Microsoft Edge などの Web ブラウザーに名前を付けることができます。 Notepad++ で作業している場合、デフォルトの白い背景が目を痛める可能性があります。開発者は Notepad++ のバージョン 8 にダーク モードを追加しました。これをオンにする方法は次のとおりです。 Windows 11/10 ++ ダーク モードのメモ帳を有効にする メモ帳 ++ を起動する 「設定」 > 「環境設定」 > 「ダーク モード」をクリックします 「ダーク モードを有効にする」を選択してメモ帳を再起動します
