成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

你會用Java代碼模擬高并發嗎?

開發 后端
Java通過代碼模擬高并發可以以最快的方式發現我們系統中潛在的線程安全性問題,此處使用Semaphore(信號量)和 CountDownLatch(閉鎖)搭配ExecutorService(線程池)來進行模擬。

 [[271769]]

 

 

Java通過代碼模擬高并發可以以最快的方式發現我們系統中潛在的線程安全性問題,此處使用Semaphore(信號量)和 CountDownLatch(閉鎖)搭配ExecutorService(線程池)來進行模擬,主要介紹如下:

1、Semaphore

JDK 1.5之后會提供這個類

Semaphore是一種基于計數的信號量。它可以設定一個閾值,基于此,多個線程競爭獲取許可信號,做完自己的申請后歸還,超過閾值后,線程申請許可信號將會被阻塞。Semaphore可以用來構建一些對象池,資源池之類的,比如數據庫連接池,我們也可以創建計數為1的Semaphore,將其作為一種類似互斥鎖的機制,這也叫二元信號量,表示兩種互斥狀態。

2、CountDownLatch

JDK 1.5之后會提供這個類,

CountDownLatch這個類能夠使一個線程等待其他線程完成各自的工作后再執行。例如,應用程序的主線程希望在負責啟動框架服務的線程已經啟動所有的框架服務之后再執行。

CountDownLatch是通過一個計數器來實現的,計數器的初始值為線程的數量。每當一個線程完成了自己的任務后,計數器的值就會減1。當計數器值到達0時,它表示所有的線程已經完成了任務,然后在閉鎖上等待的線程就可以恢復執行任務。

如下圖:

你會用Java代碼模擬高并發嗎?

 

以上兩個類可以搭配使用,達到模擬高并發的效果,以下使用代碼的形式進行舉例:

  1. package modules; 
  2. import java.util.concurrent.CountDownLatch; 
  3. import java.util.concurrent.ExecutorService; 
  4. import java.util.concurrent.Executors; 
  5. import java.util.concurrent.Semaphore; 
  6. public class CountExample { 
  7.  // 請求總數 
  8.  public static int clientTotal = 5000; 
  9.  // 同時并發執行的線程數 
  10.  public static int threadTotal = 200; 
  11.  public static int count = 0; 
  12.  public static void main(String[] args) throws Exception { 
  13.  ExecutorService executorService = Executors.newCachedThreadPool(); 
  14.  //信號量,此處用于控制并發的線程數 
  15.  final Semaphore semaphore = new Semaphore(threadTotal); 
  16.  //閉鎖,可實現計數器遞減 
  17.  final CountDownLatch countDownLatch = new CountDownLatch(clientTotal); 
  18.  for (int i = 0; i < clientTotal ; i++) { 
  19.  executorService.execute(() -> { 
  20.  try { 
  21.     //執行此方法用于獲取執行許可,當總計未釋放的許可數不超過200時, 
  22.     //允許通行,否則線程阻塞等待,直到獲取到許可。 
  23.  semaphore.acquire(); 
  24.  add(); 
  25.  //釋放許可 
  26.  semaphore.release(); 
  27.  } catch (Exception e) { 
  28.  //log.error("exception", e); 
  29.  e.printStackTrace(); 
  30.  } 
  31.  //閉鎖減一 
  32.  countDownLatch.countDown(); 
  33.  }); 
  34.  } 
  35.  countDownLatch.await();//線程阻塞,直到閉鎖值為0時,阻塞才釋放,繼續往下執行 
  36.  executorService.shutdown(); 
  37.  log.info("count:{}"count); 
  38.  } 
  39.  private static void add() { 
  40.  count++; 
  41.  } 

如上方法模擬5000次請求,同時最大200個并發操作,觀察最后的結果,發現每次的結果都有差別,和預期不符,得出結果部分如下:

  1. 22:18:26.449 [main] INFO modules.CountExample - count:4997 
  2. 22:18:26.449 [main] INFO modules.CountExample - count:5000 
  3. 22:18:26.449 [main] INFO modules.CountExample - count:4995 
  4. 22:18:26.449 [main] INFO modules.CountExample - count:4998 

最后結論:add 方法 非線程安全

那如何保證add方法 線程安全,將add方法進行如下修改即可:

  1. private static void add() { 
  2.  count.incrementAndGet(); 

執行結果如下:

  1. 22:18:26.449 [main] INFO modules.CountExample - count:5000 
  2. 22:18:26.449 [main] INFO modules.CountExample - count:5000 
  3. 22:18:26.449 [main] INFO modules.CountExample - count:5000 
  4. 22:18:26.449 [main] INFO modules.CountExample - count:5000 
  5. 22:18:26.449 [main] INFO modules.CountExample - count:5000 
  6. 22:18:26.449 [main] INFO modules.CountExample - count:5000 
  7. 22:18:26.449 [main] INFO modules.CountExample - count:5000 
  8. 22:18:26.449 [main] INFO modules.CountExample - count:5000 

最后結論:修改后 的 add 方法 線程安全

責任編輯:龐桂玉 來源: 今日頭條
相關推薦

2025-01-20 00:00:00

反射Java語言

2020-06-04 14:15:55

Java中BigDecimal函數

2018-09-29 15:34:34

JavaList接口

2021-08-11 10:00:51

緩存MyBatis管理

2021-09-06 10:42:18

Linux命令服務器

2024-03-06 08:15:03

@Autowired注入方式Spring

2021-05-21 12:36:16

限流代碼Java

2021-01-28 09:55:50

while(1)for(;;)Linux

2021-03-17 11:16:58

while(1)for(;;)語言

2019-01-28 17:42:33

Python數據預處理數據標準化

2023-12-01 11:13:50

JavaTreeSet

2023-12-07 08:13:58

Java開發

2017-02-20 07:47:04

緩存HASH高并發

2020-06-29 08:32:21

高并發程序員流量

2020-11-09 09:03:35

高并發多線程ThreadLocal

2024-04-08 00:00:00

asyncawaiPromise

2022-02-10 09:04:50

架構

2020-12-28 08:25:08

Java并發HashMap

2018-12-20 09:30:59

分布式高并發多線程

2025-01-03 08:40:53

Java并發編程Guava庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 麻豆一区一区三区四区 | 久久久国产一区二区三区 | 中文av在线播放 | 97精品久久 | 国产成人精品免高潮在线观看 | 亚洲在线中文字幕 | 欧美精品一区在线发布 | 日本午夜一区二区三区 | av天天看 | 羞羞视频在线网站观看 | 亚洲精品一区二区三区在线 | 久久精品国产99国产精品 | 亚洲精品国产电影 | www.日本在线播放 | 欧美黄色网 | 伊人久久综合影院 | 色综合国产 | 婷婷在线视频 | 天天操综合网 | 久久久久亚洲精品 | 久久婷婷国产麻豆91 | 操网站 | 男女羞羞视频网站 | 国产精品久久久久久久久图文区 | 日韩欧美一级精品久久 | 欧美在线精品一区 | 亚洲午夜av | 日本字幕在线观看 | 一区在线观看 | 欧美一区二区三区 | 久久精品国产99国产 | 亚洲福利一区二区 | 日本久草 | 午夜精品久久久久久久久久久久 | 视频一二区 | 成人a网| 久久免费大片 | 看亚洲a级一级毛片 | 亚洲成人一区 | 日韩欧美手机在线 | 亚洲精品日韩在线观看 |