亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
1. 線程池的合理使用與定制(ThreadPoolExecutor 高級(jí)配置)
2. CompletableFuture 實(shí)現(xiàn)異步編排
3. 使用 Phaser 替代 CountDownLatch 和 CyclicBarrier
4. 使用 ReadWriteLock 優(yōu)化讀多寫(xiě)少場(chǎng)景
5. StampedLock:高性能讀寫(xiě)鎖(樂(lè)觀鎖模式)
6. 并發(fā)設(shè)計(jì)模式:Thread-Local Storage 與對(duì)象池
ThreadLocal 使用場(chǎng)景
7. 使用 Disruptor 實(shí)現(xiàn)高性能事件隊(duì)列(替代 BlockingQueue)
首頁(yè) Java java教程 高級(jí)Java并發(fā)和多線程模式

高級(jí)Java并發(fā)和多線程模式

Jul 29, 2025 am 02:28 AM
java 并發(fā)編程

應(yīng)優(yōu)先使用 ThreadPoolExecutor 手動(dòng)配置線程池,選擇有界隊(duì)列、合適的拒絕策略并命名線程以避免 OOM 和便于排查問(wèn)題;2. 利用 CompletableFuture 實(shí)現(xiàn)異步任務(wù)的鏈?zhǔn)骄幣排c組合,通過(guò) thenCombine、allOf 等方法提升異步處理能力,并指定自定義線程池避免使用公共池;3. 使用 Phaser 替代 CountDownLatch 和 CyclicBarrier,因其支持動(dòng)態(tài)注冊(cè)、多階段同步和參與者注銷(xiāo),適用于復(fù)雜同步場(chǎng)景;4. 在讀多寫(xiě)少場(chǎng)景中采用 ReentrantReadWriteLock 提升并發(fā)性能,注意讀寫(xiě)鎖的獲取與釋放順序;5. 對(duì)極度讀多寫(xiě)少場(chǎng)景推薦使用 StampedLock 的樂(lè)觀讀模式,通過(guò) tryOptimisticRead 和 validate 提升性能,但需注意其不可重入且不能與 synchronized 混用;6. 使用 ThreadLocal 實(shí)現(xiàn)線程本地存儲(chǔ),適用于非線程安全對(duì)象的隔離和上下文傳遞,務(wù)必在使用后調(diào)用 remove() 防止內(nèi)存泄漏;7. 在高吞吐量場(chǎng)景如金融交易中采用 Disruptor 替代 BlockingQueue,基于環(huán)形緩沖區(qū)和無(wú)鎖設(shè)計(jì)實(shí)現(xiàn)低延遲、高吞吐的事件處理,需定義事件、工廠和處理器并配置合適策略。這些模式需根據(jù)實(shí)際場(chǎng)景選擇使用,才能有效提升系統(tǒng)性能與穩(wěn)定性。

Advanced Java Concurrency and Multithreading Patterns

Java 的并發(fā)與多線程編程是構(gòu)建高性能、可擴(kuò)展應(yīng)用的關(guān)鍵。隨著現(xiàn)代應(yīng)用對(duì)響應(yīng)性、吞吐量和資源利用率的要求越來(lái)越高,掌握高級(jí)并發(fā)模式變得尤為重要。本文將深入探討幾種在實(shí)際開(kāi)發(fā)中非常有用的高級(jí) Java 并發(fā)與多線程模式,幫助你寫(xiě)出更健壯、高效的并發(fā)代碼。

Advanced Java Concurrency and Multithreading Patterns

1. 線程池的合理使用與定制(ThreadPoolExecutor 高級(jí)配置)

雖然 Executors 工具類(lèi)提供了便捷的線程池創(chuàng)建方式,但在生產(chǎn)環(huán)境中直接使用 newFixedThreadPoolnewCachedThreadPool 容易引發(fā)問(wèn)題(如 OOM)。更推薦使用 ThreadPoolExecutor 手動(dòng)配置。

ThreadPoolExecutor executor = new ThreadPoolExecutor(
    5,                    // 核心線程數(shù)
    10,                   // 最大線程數(shù)
    60L,                  // 空閑線程存活時(shí)間
    TimeUnit.SECONDS,
    new LinkedBlockingQueue<>(100), // 任務(wù)隊(duì)列
    new CustomThreadFactory(),      // 線程工廠(可命名線程)
    new ThreadPoolExecutor.CallerRunsPolicy() // 拒絕策略
);

關(guān)鍵點(diǎn):

Advanced Java Concurrency and Multithreading Patterns
  • 隊(duì)列選擇ArrayBlockingQueue(有界)比 LinkedBlockingQueue(默認(rèn)無(wú)界)更安全。
  • 拒絕策略
    • AbortPolicy:拋異常(默認(rèn))
    • CallerRunsPolicy:由提交任務(wù)的線程執(zhí)行(可防止雪崩)
  • 線程命名:通過(guò) ThreadFactory 設(shè)置有意義的線程名,便于排查問(wèn)題。

2. CompletableFuture 實(shí)現(xiàn)異步編排

CompletableFuture 是 Java 8 引入的強(qiáng)大的異步編程工具,支持鏈?zhǔn)秸{(diào)用、組合多個(gè)異步任務(wù)。

CompletableFuture<String> future1 = CompletableFuture.supplyAsync(() -> {
    // 模擬耗時(shí)操作
    sleep(1000);
    return "Result1";
});

CompletableFuture<String> future2 = CompletableFuture.supplyAsync(() -> {
    sleep(800);
    return "Result2";
});

// 組合兩個(gè)任務(wù)
CompletableFuture<String> combined = future1.thenCombine(future2, (r1, r2) -> r1   "-"   r2);

combined.thenAccept(System.out::println).join();

常用方法:

Advanced Java Concurrency and Multithreading Patterns
  • thenApply():轉(zhuǎn)換結(jié)果
  • thenCompose():串行異步任務(wù)(flatMap 語(yǔ)義)
  • allOf() / anyOf():多個(gè)任務(wù)同步或任一完成
  • 自定義線程池:避免使用 ForkJoinPool.commonPool()
CompletableFuture.supplyAsync(() -> compute(), executor);

3. 使用 Phaser 替代 CountDownLatch 和 CyclicBarrier

Phaser 是一個(gè)更靈活的同步工具,支持動(dòng)態(tài)注冊(cè)參與者、可重用、可分階段。

Phaser phaser = new Phaser();
phaser.register(); // 主線程也參與

for (int i = 0; i < 3; i  ) {
    phaser.register();
    new Thread(() -> {
        System.out.println(Thread.currentThread().getName()   " 開(kāi)始第一階段");
        phaser.arriveAndAwaitAdvance(); // 等待所有人到達(dá)

        System.out.println(Thread.currentThread().getName()   " 開(kāi)始第二階段");
        phaser.arriveAndAwaitAdvance();

        phaser.arriveAndDeregister(); // 完成并注銷(xiāo)
    }).start();
}

phaser.arriveAndDeregister(); // 主線程退出

優(yōu)勢(shì):

  • 動(dòng)態(tài)增減參與線程
  • 支持多階段同步
  • 可以監(jiān)聽(tīng)每個(gè)階段的開(kāi)始和結(jié)束(通過(guò) onAdvance()

4. 使用 ReadWriteLock 優(yōu)化讀多寫(xiě)少場(chǎng)景

在高并發(fā)讀、低頻寫(xiě)的場(chǎng)景中,ReentrantReadWriteLock 能顯著提升性能。

public class Cache {
    private final Map<String, String> map = new HashMap<>();
    private final ReadWriteLock lock = new ReentrantReadWriteLock();
    private final Lock readLock = lock.readLock();
    private final Lock writeLock = lock.writeLock();

    public String get(String key) {
        readLock.lock();
        try {
            return map.get(key);
        } finally {
            readLock.unlock();
        }
    }

    public void put(String key, String value) {
        writeLock.lock();
        try {
            map.put(key, value);
        } finally {
            writeLock.unlock();
        }
    }
}

注意:

  • 讀鎖不互斥,寫(xiě)鎖獨(dú)占
  • 不可重入寫(xiě)鎖到讀鎖(會(huì)死鎖),需顯式釋放再獲取
  • JDK 17 推薦考慮 StampedLock(樂(lè)觀讀)

5. StampedLock:高性能讀寫(xiě)鎖(樂(lè)觀鎖模式)

StampedLock 提供了三種模式:寫(xiě)鎖、悲觀讀鎖、樂(lè)觀讀鎖,適合極度讀多寫(xiě)少的場(chǎng)景。

public class Point {
    private double x, y;
    private final StampedLock sl = new StampedLock();

    public double distanceFromOrigin() {
        long stamp = sl.tryOptimisticRead(); // 樂(lè)觀讀
        double currentX = x, currentY = y;

        if (!sl.validate(stamp)) { // 檢查期間是否有寫(xiě)操作
            stamp = sl.readLock(); // 升級(jí)為悲觀讀
            try {
                currentX = x;
                currentY = y;
            } finally {
                sl.unlockRead(stamp);
            }
        }
        return Math.sqrt(currentX * currentX   currentY * currentY);
    }
}

優(yōu)點(diǎn):

  • 樂(lè)觀讀不阻塞寫(xiě),性能極高
  • 寫(xiě)操作優(yōu)先級(jí)高

缺點(diǎn):

  • 不可重入
  • 不能與 synchronized 混用
  • 鎖狀態(tài)通過(guò) long stamp 管理,需小心使用

6. 并發(fā)設(shè)計(jì)模式:Thread-Local Storage 與對(duì)象池

ThreadLocal 使用場(chǎng)景

private static final ThreadLocal<SimpleDateFormat> formatter = ThreadLocal.withInitial(
    () -> new SimpleDateFormat("yyyy-MM-dd")
);

public String formatDate(Date date) {
    return formatter.get().format(date);
}

適用于:

  • 非線程安全工具類(lèi)的隔離(如 SimpleDateFormat
  • 上下文傳遞(如用戶身份、請(qǐng)求 ID)

注意內(nèi)存泄漏:

  • ThreadLocalEntryWeakReference,但值仍可能泄漏
  • 建議使用后調(diào)用 remove()
formatter.remove();

7. 使用 Disruptor 實(shí)現(xiàn)高性能事件隊(duì)列(替代 BlockingQueue)

在超高吞吐場(chǎng)景(如金融交易、日志系統(tǒng)),DisruptorBlockingQueue 性能更好,基于環(huán)形緩沖區(qū)和無(wú)鎖設(shè)計(jì)。

基本使用步驟:

  • 定義事件類(lèi)
  • 創(chuàng)建事件工廠
  • 定義事件處理器(EventHandler)
  • 構(gòu)建 Disruptor 實(shí)例并啟動(dòng)
Disruptor<LongEvent> disruptor = new Disruptor<>(
    LongEvent::new,
    bufferSize,
    Executors.defaultThreadFactory(),
    ProducerType.MULTI,
    new BlockingWaitStrategy()
);

優(yōu)勢(shì):

  • 無(wú)鎖生產(chǎn)者/消費(fèi)者
  • 高吞吐、低延遲
  • 預(yù)分配對(duì)象,減少 GC

基本上就這些。這些高級(jí)并發(fā)模式在實(shí)際項(xiàng)目中能顯著提升系統(tǒng)的穩(wěn)定性與性能。關(guān)鍵不是堆砌技術(shù),而是根據(jù)場(chǎng)景選擇合適的工具:

  • 一般異步用 CompletableFuture
  • 高并發(fā)讀用 StampedLock
  • 多階段同步用 Phaser
  • 高吞吐隊(duì)列考慮 Disruptor

不復(fù)雜,但容易忽略細(xì)節(jié)。

以上是高級(jí)Java并發(fā)和多線程模式的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

用雅加達(dá)EE在Java建立靜止的API 用雅加達(dá)EE在Java建立靜止的API Jul 30, 2025 am 03:05 AM

SetupaMaven/GradleprojectwithJAX-RSdependencieslikeJersey;2.CreateaRESTresourceusingannotationssuchas@Pathand@GET;3.ConfiguretheapplicationviaApplicationsubclassorweb.xml;4.AddJacksonforJSONbindingbyincludingjersey-media-json-jackson;5.DeploytoaJakar

Java項(xiàng)目管理Maven的開(kāi)發(fā)人員指南 Java項(xiàng)目管理Maven的開(kāi)發(fā)人員指南 Jul 30, 2025 am 02:41 AM

Maven是Java項(xiàng)目管理和構(gòu)建的標(biāo)準(zhǔn)工具,答案在于它通過(guò)pom.xml實(shí)現(xiàn)項(xiàng)目結(jié)構(gòu)標(biāo)準(zhǔn)化、依賴管理、構(gòu)建生命周期自動(dòng)化和插件擴(kuò)展;1.使用pom.xml定義groupId、artifactId、version和dependencies;2.掌握核心命令如mvnclean、compile、test、package、install和deploy;3.利用dependencyManagement和exclusions管理依賴版本與沖突;4.通過(guò)多模塊項(xiàng)目結(jié)構(gòu)組織大型應(yīng)用并由父POM統(tǒng)一管理;5.配

如何將Java MistageDigest用于哈希(MD5,SHA-256)? 如何將Java MistageDigest用于哈希(MD5,SHA-256)? Jul 30, 2025 am 02:58 AM

要使用Java生成哈希值,可通過(guò)MessageDigest類(lèi)實(shí)現(xiàn)。1.獲取指定算法的實(shí)例,如MD5或SHA-256;2.調(diào)用.update()方法傳入待加密數(shù)據(jù);3.調(diào)用.digest()方法獲取哈希字節(jié)數(shù)組;4.將字節(jié)數(shù)組轉(zhuǎn)換為十六進(jìn)制字符串以便讀取;對(duì)于大文件等輸入,應(yīng)分塊讀取并多次調(diào)用.update();推薦使用SHA-256而非MD5或SHA-1以確保安全性。

CSS暗模式切換示例 CSS暗模式切換示例 Jul 30, 2025 am 05:28 AM

首先通過(guò)JavaScript獲取用戶系統(tǒng)偏好和本地存儲(chǔ)的主題設(shè)置,初始化頁(yè)面主題;1.HTML結(jié)構(gòu)包含一個(gè)按鈕用于觸發(fā)主題切換;2.CSS使用:root定義亮色主題變量,.dark-mode類(lèi)定義暗色主題變量,并通過(guò)var()應(yīng)用這些變量;3.JavaScript檢測(cè)prefers-color-scheme并讀取localStorage決定初始主題;4.點(diǎn)擊按鈕時(shí)切換html元素上的dark-mode類(lèi),并將當(dāng)前狀態(tài)保存至localStorage;5.所有顏色變化均帶有0.3秒過(guò)渡動(dòng)畫(huà),提升用戶

CSS下拉菜單示例 CSS下拉菜單示例 Jul 30, 2025 am 05:36 AM

是的,一個(gè)常見(jiàn)的CSS下拉菜單可以通過(guò)純HTML和CSS實(shí)現(xiàn),無(wú)需JavaScript。1.使用嵌套的ul和li構(gòu)建菜單結(jié)構(gòu);2.通過(guò):hover偽類(lèi)控制下拉內(nèi)容的顯示與隱藏;3.父級(jí)li設(shè)置position:relative,子菜單使用position:absolute進(jìn)行定位;4.子菜單默認(rèn)display:none,懸停時(shí)變?yōu)閐isplay:block;5.可通過(guò)嵌套實(shí)現(xiàn)多級(jí)下拉,結(jié)合transition添加淡入動(dòng)畫(huà),配合媒體查詢適配移動(dòng)端,整個(gè)方案簡(jiǎn)潔且無(wú)需JavaScript支持,適合大

VSCODE設(shè)置。JSON位置 VSCODE設(shè)置。JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位于用戶級(jí)或工作區(qū)級(jí)路徑,用于自定義VSCode設(shè)置。1.用戶級(jí)路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級(jí)路徑:項(xiàng)目根目錄下的.vscode/settings

Python Parse Date String示例 Python Parse Date String示例 Jul 30, 2025 am 03:32 AM

使用datetime.strptime()可將日期字符串轉(zhuǎn)換為datetime對(duì)象,1.基本用法:通過(guò)"%Y-%m-%d"解析"2023-10-05"為datetime對(duì)象;2.支持多種格式如"%m/%d/%Y"解析美式日期、"%d/%m/%Y"解析英式日期、"%b%d,%Y%I:%M%p"解析帶AM/PM的時(shí)間;3.可用dateutil.parser.parse()自動(dòng)推斷未知格式;4.使用.d

崇高文本自動(dòng)關(guān)閉HTML標(biāo)簽 崇高文本自動(dòng)關(guān)閉HTML標(biāo)簽 Jul 30, 2025 am 02:41 AM

安裝Emmet插件可實(shí)現(xiàn)智能自動(dòng)閉合標(biāo)簽并支持縮寫(xiě)語(yǔ)法;2.啟用"auto_match_enabled":true讓Sublime自動(dòng)補(bǔ)全簡(jiǎn)單標(biāo)簽;3.使用Alt .(Win)或Ctrl Shift .(Mac)快捷鍵手動(dòng)閉合當(dāng)前標(biāo)簽——推薦日常使用Emmet,輕量需求可用后兩種方式組合,效率足夠且設(shè)置簡(jiǎn)單。

See all articles