激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Java中ConcurrentHashMap是如何實現(xiàn)線程安全

Java中ConcurrentHashMap是如何實現(xiàn)線程安全

2022-03-10 01:06海擁 Java教程

ConcurrentHashMap是一個哈希表,支持檢索的全并發(fā)和更新的高預(yù)期并發(fā)。本文主要介紹了Java中ConcurrentHashMap是如何實現(xiàn)線程安全,感興趣的可以了解一下

ConcurrentHashMap是一個哈希表,支持檢索的全并發(fā)和更新的高預(yù)期并發(fā)。此類遵循與 Hashtable 相同的功能規(guī)范,并包含 Hashtable 的所有方法。ConcurrentHashMap 位于 java.util.Concurrent 包中。

語法:

?
1
2
3
public class ConcurrentHashMap<K,V>
extends AbstractMap<K,V>
implements ConcurrentMap<K,V>, Serializable

其中 K 指的是這個映射所維護(hù)的鍵的類型,V 指的是映射值的類型

ConcurrentHashmap 的需要:

  • HashMap雖然有很多優(yōu)點,但不能用于多線程,因為它不是線程安全的。
  • 盡管 Hashtable 被認(rèn)為是線程安全的,但它也有一些缺點。例如,Hashtable 需要鎖定才能讀取打開,即使它不影響對象。
  • n HashMap,如果一個線程正在迭代一個對象,另一個線程試圖訪問同一個對象,它會拋出 ConcurrentModificationException,而并發(fā) hashmap 不會拋出 ConcurrentModificationException。

如何使 ConcurrentHashMap 線程安全成為可能?

  • java.util.Concurrent.ConcurrentHashMap類通過將map劃分為segment來實現(xiàn)線程安全,不是整個對象需要鎖,而是一個segment,即一個線程需要一個segment的鎖。
  • 在 ConcurrenHashap 中,讀操作不需要任何鎖。

示例 1:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
import java.util.*;
import java.util.concurrent.*;
 
// 擴(kuò)展Thread類的主類
class GFG extends Thread {
 
 // 創(chuàng)建靜態(tài) HashMap 類對象
 static HashMap m = new HashMap();
 
 public void run()
 {
 
  // try 塊檢查異常
  try {
 
   // 讓線程休眠 3 秒
   Thread.sleep(2000);
  }
  catch (InterruptedException e) {
  }
  System.out.println("子線程更新映射");
  m.put(103, "C");
 }
 public static void main(String arg[])
  throws InterruptedException
 {
  m.put(101, "A");
  m.put(102, "B");
  GFG t = new GFG();
  t.start();
  Set s1 = m.keySet();
  Iterator itr = s1.iterator();
  while (itr.hasNext()) {
   Integer I1 = (Integer)itr.next();
   System.out.println(
    "主線程迭代映射和當(dāng)前條目是:"
    + I1 + "..." + m.get(I1));
   Thread.sleep(3000);
  }
  System.out.println(m);
 }
}

輸出:
主線程迭代映射和當(dāng)前條目是:101...A
子線程更新映射
Exception in thread "main" java.util.ConcurrentModificationException
       at java.base/java.util.HashMap$HashIterator.nextNode(HashMap.java:1493)
       at java.base/java.util.HashMap$KeyIterator.next(HashMap.java:1516)
       at Main.main(Main.java:30)

輸出說明:

上述程序中使用的類擴(kuò)展了 Thread 類。讓我們看看控制流。所以,最初,上面的java程序包含一個線程。當(dāng)我們遇到語句 Main t= new Main() 時,我們正在為擴(kuò)展 Thread 類的類創(chuàng)建一個對象。因此,每當(dāng)我們調(diào)用 t.start() 方法時,子線程都會被激活并調(diào)用 run() 方法. 現(xiàn)在主線程開始執(zhí)行,每當(dāng)子線程更新同一個地圖對象時,都會拋出一個名為 ConcurrentModificationException 的異常。    

現(xiàn)在讓我們使用 ConcurrentHashMap 來修改上面的程序,以解決上述程序在執(zhí)行時產(chǎn)生的異常。

示例 2:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import java.util.*;
import java.util.concurrent.*;
 
class Main extends Thread {
 static ConcurrentHashMap<Integer, String> m
  = new ConcurrentHashMap<Integer, String>();
 public void run()
 {
  try {
   Thread.sleep(2000);
  }
  catch (InterruptedException e) {
  }
  System.out.println("子線程更新映射");
  m.put(103, "C");
 }
 public static void main(String arg[])
  throws InterruptedException
 {
  m.put(101, "A");
  m.put(102, "B");
  Main t = new Main();
  t.start();
  Set<Integer> s1 = m.keySet();
  Iterator<Integer> itr = s1.iterator();
  while (itr.hasNext()) {
   Integer I1 = itr.next();
   System.out.println(
    "主線程迭代映射和當(dāng)前條目是:"
    + I1 + "..." + m.get(I1));
   Thread.sleep(3000);
  }
  System.out.println(m);
 }
}

輸出

主線程迭代映射和當(dāng)前條目是:101...A
子線程更新映射
主線程迭代映射和當(dāng)前條目是:102...B
主線程迭代映射和當(dāng)前條目是:103...C
{101=A, 102=B, 103=C}

輸出說明:
上述程序中使用的 Class 擴(kuò)展了Thread 類。讓我們看看控制流,所以我們知道在 ConcurrentHashMap 中,當(dāng)一個線程正在迭代時,剩余的線程可以以安全的方式執(zhí)行任何修改。上述程序中主線程正在更新Map,同時子線程也在嘗試更新Map對象。本程序不會拋出 ConcurrentModificationException。

Hashtable、Hashmap、ConcurrentHashmap的區(qū)別

 

Hashtable Hashmap ConcurrentHashmap
我們將通過鎖定整個地圖對象來獲得線程安全。 它不是線程安全的。 我們將獲得線程安全,而無需使用段級鎖鎖定 Total Map 對象。
每個讀寫操作都需要一個objectstotal 映射對象鎖。 它不需要鎖。 讀操作可以不加鎖執(zhí)行,寫操作可以用段級鎖執(zhí)行。
一次只允許一個線程在地圖上操作(同步) 不允許同時運(yùn)行多個線程。它會拋出異常 一次允許多個線程以安全的方式操作地圖對象
當(dāng)一個線程迭代 Map 對象時,其他線程不允許修改映射,否則我們會得到 ConcurrentModificationException 當(dāng)一個線程迭代 Map 對象時,其他線程不允許修改映射,否則我們會得到 ConcurrentModificationException 當(dāng)一個線程迭代 Map 對象時,其他線程被允許修改地圖,我們不會得到 ConcurrentModificationException
鍵和值都不允許為 Null HashMap 允許一個空鍵和多個空值 鍵和值都不允許為 Null。
在 1.0 版本中引入 在 1.2 版本中引入 在 1.5 版本中引入

 

到此這篇關(guān)于Java中ConcurrentHashMap是如何實現(xiàn)線程安全的文章就介紹到這了,更多相關(guān)Java ConcurrentHashMap線程安全內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://juejin.cn/post/7026239741993418766

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品免费观在线 | 91久久久久久久久久久久久 | 国产精品成人一区二区三区电影毛片 | 免费在线观看国产精品 | 国产一区二区三区色淫影院 | 久久国产成人午夜av浪潮 | 成人羞羞视频在线观看 | 亚洲午夜视频 | 毛片毛片免费看 | 国产系列 视频二区 | 国产一区毛片 | 失禁高潮抽搐喷水h | 在线观看第一区 | 亚洲性生活免费视频 | 一区在线免费视频 | 久久精品国产99久久6动漫亮点 | 欧美曾交 | 姑娘第5集高清在线观看 | 国产一区二区三区四区波多野结衣 | 久久国产精品成人免费网站 | 久久亚洲国产精品 | 天天舔夜夜操 | 精品无码一区在线观看 | 91看片淫黄大片欧美看国产片 | 超碰97国产在线 | 色啪综合| 92看片淫黄大片一级 | 国产精品久久久久一区二区 | 亚洲一级电影在线观看 | 久久精品欧美视频 | 一区二区久久久久草草 | 精品在线视频观看 | 极色品影院 | 天天草夜夜骑 | 天天鲁在线视频免费观看 | 九九精品久久 | 12av毛片 | 国av在线 | www.热| 一起草av在线 | 黑人一区二区 |