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

目次
基本的な使用:先物の作成と完了
thenApplythenAccept 、およびthenRunで操作をチェーンします
先物とthenComposethenCombineを組み合わせる
exceptionallyhandleでエラーを処理します
スレッドをより適切に制御するためのAsyncバージョン
ホームページ Java &#&チュートリアル `completablefuture」とは何ですか?

`completablefuture」とは何ですか?

Jun 26, 2025 am 01:05 AM

JavaのCompletableFutureは、従來の將來のインターフェイスよりも柔軟性が高い非ブロッキングコードを有効にすることにより、非同期プログラミングを簡素化します。 1.完全な()、2。runasync()またはsuppelyasync()、3を介した非yync実行をサポートするタスクを手動で完了させることができます。値)とハンドル(カスタムエラー/結(jié)果処理)、および6。スレッド制御、非同期ワークフローの並列性と読みやすさを高める方法の非同期バージョンを提供します。

`completablefuture」とは何ですか?

CompletableFutureは、 java.util.concurrentパッケージの一部としてJava 8に導入されたJavaのクラスです。これは、古いFutureインターフェイスよりも、先物(非同期計算の結(jié)果)をよりきれいかつ柔軟に処理する非ブロッキングコードを作成できるようにすることで、非同期プログラミングを容易にするように設計されています。

CompletableFutureの背後にある主なアイデアは、例外の取り扱い、複數(shù)の先物の組み合わせ、次のステップを?qū)g行するスレッドを指定するなど、タスクがどのように連鎖され、組み合わされているかをより制御できることです。


基本的な使用:先物の作成と完了

いくつかの方法でCompletableFuture顧客を作成できます。

  • complete()を使用して手動で完了します
  • runAsync()supplyAsync()などの方法を使用して非同期タスクを?qū)g行します

例えば:

 completeablefuture <string> future = completablefuture.supplyasync(() - > {{
    //長期にわたるタスクをシミュレートします
    試す {
        thread.sleep(1000);
    } catch(arternedexception e){}
    「こんにちは」を返します。
});

future.thenaccept(result-> system.out.println( "result:" result));

これにより、1秒後に「Hello」を返す背景タスクが設定され、完了したら印刷します。

未來を手動で完了したい場合(たとえば、テストやカスタムロジックなど)、次のことができます。

 completeablefuture <integer> manualfuture = new completablefuture <>();
ManualFuture.comPlete(42);
ManicalFuture.thenaccept(system.out :: println); //印刷42

thenApply 、 thenAccept 、およびthenRunで操作をチェーンします

CompletableFuture財政の大きな利點の1つは、スレッドをブロックせずに操作をチェーンする機能です。

各メソッドの仕組みは次のとおりです。

  • thenApply結(jié)果を変換します
  • thenAccept結(jié)果を消費しますが、何も返さない
  • thenRun 、結(jié)果を無視して、完了後にいくつかのコードを?qū)g行します

例:

 completeablefuture <integer> future = completablefuture.supplyasync(() - > "apple")
    .thenapply(s-> s.length())//「Apple」を5に変えます
    .thenapply(len-> len * 2); // 5は10になります

future.thenaccept(system.out :: println); //印刷10

これらの操作は通常、別のエグゼキューターを指定しない限り、以前の將來を完了したのと同じスレッドで実行されます。


先物とthenComposethenCombineを組み合わせる

複數(shù)の非同期ステップで作業(yè)する場合、2つの重要な方法は次のとおりです。

  • thenCompose - 別の未來を返す未來がある場合にこれを使用してください
  • thenCombine - 2つの獨立した先物の結(jié)果を組み合わせるときにこれを使用してください

例えば:

 completeablefuture <integer> future1 = completablefuture.supplyasync(() - > 10);
completeablefuture <integer> future2 = completablefuture.supplyasync(() - > 20);

//両方の結(jié)果を結(jié)合します
future1.thencombine(future2、(a、b) - > ab)
       .thenaccept(system.out :: println); // 30を印刷します

そして、あなたが未來の中で未來を返しているなら:

 CompletableFuture <Integer> composed = completablefuture.supplyasync(() - > 5)
    .thencompose(val-> completeablefuture.supplyasync(() - > val * 2));

composed.thenaccept(system.out :: println); //印刷10

exceptionallyhandleでエラーを処理します

物事は常にスムーズに進むとは限りません。以下を使用して例外を処理できます。

  • exceptionally - エラーが発生した場合、フォールバック値を提供します
  • handle - 結(jié)果と例外の両方を検査し、何を返すかを選択できます

例:

 completeablefuture <integer> faultyfuture = completeablefuture.supplyasync(() - > {{
    (true)new runtimeexception( "oops!")を投げるif(true);
    100を返します。
});

faultyfuture
    .exceptally(ex-> {
        system.out.println( "エラーが発生しました:" ex.getMessage());
        0を返します。 //フォールバック値
    })
    .thenaccept(system.out :: println); //印刷0

handleを使用すると、柔軟性が高まります。

 completeablefuture <integer> handled = faultyfuture.handle((result、ex) - > {
    if(ex!= null){
        System.out.println( "処理エラー:" ex.getMessage());
        返品1; // デフォルト
    }
    返品結(jié)果;
});

スレッドをより適切に制御するためのAsyncバージョン

ほとんどの方法には、次の操作に使用するスレッドプールを指定できる非同期バージョン( thenApplyAsync 、 thenAcceptAsyncなど)が付屬しています。

これは、元のスレッドのブロックを避けたり、作業(yè)を並行したりしたい場合に役立ちます。

例:

 completeablefuture <integer> future = completablefuture.supplyasync(() - > 10)
    .thenapplyasync(val-> val * 2、executors.newfixedthreadpool(2));

これにより、乗算が個別のスレッドプールで行われます。


したがって、基本的に、 CompletableFuture 、Javaできれいで読みやすく、効率的な非同期コードを書くのに役立ちます。コールバック地獄で立ち往生することなく、非同期タスクを簡単にチェーン、組み合わせ、管理するためのツールを提供することにより、古いFutureインターフェイスの上に構(gòu)築されます。

それがその核心です。パターンに慣れたら、それほど複雑ではありません。

以上が`completablefuture」とは何ですか?の詳細內(nèi)容です。詳細については、PHP 中國語 Web サイトの他の関連記事を參照してください。

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

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國語版

SublimeText3 中國語版

中國語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

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

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

現(xiàn)代のジャワの非同期プログラミング技術(shù) 現(xiàn)代のジャワの非同期プログラミング技術(shù) Jul 07, 2025 am 02:24 AM

Javaは、Java19での完了可能なストリーム(ProjectReactorなど)、仮想スレッドの使用など、非同期プログラミングをサポートしています。 1.CompletableFutureチェーンコールを通じてコードの読みやすさとメンテナンスを改善し、タスクオーケストレーションと例外処理をサポートします。 2。ProjectReactorは、バックプレッシャーメカニズムとリッチ演算子を備えた応答性プログラミングを?qū)g裝するためのモノとフラックスタイプを提供します。 3.仮想スレッドは、同時性コストを削減し、I/O集約型タスクに適しており、従來のプラットフォームスレッドよりも軽量で拡張が容易です。各方法には適用可能なシナリオがあり、適切なツールをお客様のニーズに応じて選択する必要があり、混合モデルはシンプルさを維持するために避ける必要があります

Javaで酵素を使用するためのベストプラクティス Javaで酵素を使用するためのベストプラクティス Jul 07, 2025 am 02:35 AM

Javaでは、列挙は固定定數(shù)セットを表すのに適しています。ベストプラクティスには以下が含まれます。1。列挙を使用して固定狀態(tài)またはオプションを表して、タイプの安全性と読みやすさを改善します。 2.フィールド、コンストラクター、ヘルパーメソッドなどの定義など、柔軟性を高めるために、酵素にプロパティとメソッドを追加します。 3. enummapとEnumsetを使用して、パフォーマンスとタイプの安全性を向上させ、配列に??基づいてより効率的であるためです。 4.動的値、頻繁な変更、複雑なロジックシナリオなどの列挙の悪用を避けてください。これらは他の方法に置き換える必要があります。列挙の正しい使用は、コードの品質(zhì)を改善し、エラーを減らすことができますが、適用される境界に注意を払う必要があります。

Java Nioとその利點を理解する Java Nioとその利點を理解する Jul 08, 2025 am 02:55 AM

Javanioは、Java 1.4によって導入された新しいIoapiです。 1)バッファとチャネルを?qū)澫螭趣筏皮い蓼埂?)バッファ、チャネル、セレクターのコアコンポーネント、3)ノンブロッキングモードをサポートし、4)従來のIOよりも効率的に並行接続を処理します。その利點は、次のことに反映されます。1)非ブロッキングIOはスレッドオーバーヘッドを減らし、2)データ送信効率を改善し、3)セレクターがマルチプレックスを?qū)g現(xiàn)し、4)メモリマッピングはファイルの読み取りと書き込みを速めます。注:1)バッファのフリップ/クリア操作は混亂しやすく、2)不完全なデータをブロックせずに手動で処理する必要があります。3)セレクター登録は時間內(nèi)にキャンセルする必要があります。4)NIOはすべてのシナリオに適していません。

ハッシュマップはJavaで內(nèi)部的にどのように機能しますか? ハッシュマップはJavaで內(nèi)部的にどのように機能しますか? Jul 15, 2025 am 03:10 AM

HashMapは、Javaのハッシュテーブルを介してキーと値のペアストレージを?qū)g裝し、そのコアはデータの位置をすばやく配置することにあります。 1.最初にキーのHashCode()メソッドを使用して、ハッシュ値を生成し、ビット操作を介して配列インデックスに変換します。 2。異なるオブジェクトは、同じハッシュ値を生成し、競合をもたらす場合があります。この時點で、ノードはリンクされたリストの形式で取り付けられています。 JDK8の後、リンクされたリストが長すぎ(デフォルトの長さ8)、効率を改善するために赤と黒の木に変換されます。 3.カスタムクラスをキーとして使用する場合、equals()およびhashcode()メソッドを書き直す必要があります。 4。ハッシュマップは容量を動的に拡大します。要素の數(shù)が容量を超え、負荷係數(shù)(デフォルト0.75)を掛けた場合、拡張して再ハッシュします。 5。ハッシュマップはスレッドセーフではなく、マルチスレッドでconcuを使用する必要があります

Java EnumsとBest Practicesの効果的な使用 Java EnumsとBest Practicesの効果的な使用 Jul 07, 2025 am 02:43 AM

Javaの列挙は、定數(shù)を表すだけでなく、動作をカプセル化し、データをキャリーし、インターフェイスを?qū)g裝することもできます。 1.列挙は、週や狀態(tài)などの固定インスタンスを定義するために使用されるクラスであり、文字列や整數(shù)よりも安全です。 2。コンストラクターに値を渡すことやアクセス方法の提供など、データとメソッドを運ぶことができます。 3.スイッチを使用して、明確な構(gòu)造を持つさまざまなロジックを処理できます。 4.さまざまな列挙値の差別化された動作を作成するためのインターフェイスまたは抽象的なメソッドを?qū)g裝できます。 5.虐待、ハードコードの比較、順序の値への依存、合理的に命名とシリアル化を避けるために注意してください。

JavaのSingletonデザインパターンとは何ですか? JavaのSingletonデザインパターンとは何ですか? Jul 09, 2025 am 01:32 AM

JavaのSingleton Design Patternは、クラスに1つのインスタンスしかないことを保証し、プライベートコンストラクターと靜的方法を介したグローバルアクセスポイントを提供することを保証します。これは、共有リソースへのアクセスを制御するのに適しています。実裝方法には以下が含まれます。1。レイジーロード、つまり、インスタンスは最初のリクエストが要求されたときにのみ作成されます。これは、リソースの消費が高く、必ずしも必要ではない狀況に適しています。 2。スレッドセーフ処理。同期方法または再確認ロックを介して、マルチスレッド環(huán)境で1つのインスタンスのみが作成され、パフォーマンスへの影響が低下するようにします。 3.クラスの読み込み中にインスタンスを直接初期化するHungry Loadingは、事前に初期化できる軽量オブジェクトまたはシナリオに適しています。 4.列挙の実裝は、Java列挙を使用してシリアル化、スレッドの安全性をサポートし、反射攻撃を防止することは、推奨される簡潔で信頼できる方法です。特定のニーズに応じて、さまざまな実裝方法を選択できます

Javaオプションの例 Javaオプションの例 Jul 12, 2025 am 02:55 AM

オプションは、意図を明確に表現(xiàn)し、ヌルの判斷のコードノイズを減らすことができます。 1. optional.ofnullableは、nullオブジェクトに対処する一般的な方法です。たとえば、マップから値を取得する場合、Orelseを使用してデフォルト値を提供できるため、ロジックはより明確かつ簡潔になります。 2.チェーンコールマップを使用してネストされた値を達成してNPEを安全に回避し、リンクが無効である場合はデフォルト値を返す場合は自動的に終了します。 3.フィルターは條件付きフィルタリングに使用でき、その後の操作は條件が満たされた場合にのみ実行され続けます。そうしないと、軽量のビジネス判斷に適したOrelseに直接ジャンプします。 4.基本的なタイプや単純なロジックなど、複雑さを高めるなど、オプションを過剰使用することはお勧めしません。一部のシナリオはNUに直接戻ります。

java.io.notserializableExceptionを修正する方法は? java.io.notserializableExceptionを修正する方法は? Jul 12, 2025 am 03:07 AM

java.io.notserializableExceptionに遭遇するためのコアワークアウンドは、シリアル化する必要があるすべてのクラスがシリアル化可能なインターフェイスを?qū)g裝し、ネストされたオブジェクトのシリアル化サポートを確認することです。 1.メインクラスに機器を追加する可能性のあるものを追加します。 2.クラス內(nèi)の対応するカスタムフィールドのクラスも、シリアル化可能なものを?qū)g裝していることを確認します。 3.一時的に使用して、シリアル化する必要のないフィールドをマークする。 4.コレクションまたはネストされたオブジェクトの非シリアル化されたタイプを確認します。 5.どのクラスがインターフェイスを?qū)g裝していないかを確認します。 6.キーデータの保存やシリアル化可能な中間構(gòu)造の使用など、変更できないクラスの交換設計を検討します。 7.変更を検討してください

See all articles