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

首頁 Java Java基礎(chǔ) hashmap和concurrenthashmap的差別是什麼

hashmap和concurrenthashmap的差別是什麼

Feb 02, 2021 am 11:14 AM
concurrenthashmap hashmap java

區(qū)別:HashMap是線程不安全的,當(dāng)出現(xiàn)多線程操作時(shí),會(huì)出現(xiàn)安全隱患;而ConcurrentHashMap是線程安全的。 HashMap不支援並發(fā)操作,沒有同步方法;ConcurrentHashMap支援並發(fā)操作。

hashmap和concurrenthashmap的差別是什麼

本教學(xué)操作環(huán)境:windows7系統(tǒng)、java10版,DELL G3電腦。

hashmap與concurrenthashmap的差異

  • HashMap是執(zhí)行緒不安全的,當(dāng)出現(xiàn)多執(zhí)行緒操作時(shí),會(huì)出現(xiàn)安全隱患;而ConcurrentHashMap是線程安全的。

  • HashMap不支援並發(fā)操作,沒有同步方法,ConcurrentHashMap支援並發(fā)操作,透過繼承ReentrantLock(JDK1.7重入鎖定)/CAS和synchronized(JDK1.8內(nèi)建鎖定)來進(jìn)行加鎖(分段鎖),每次需要加鎖的操作鎖住的是一個(gè)segment,這樣只要確保每個(gè)Segment 是線程安全的,也就實(shí)現(xiàn)了全局的線程安全。

ConcurrentHashMap採用鎖定分段技術(shù),將整個(gè)Hash桶進(jìn)行了分段segment,也就是將這個(gè)大的數(shù)組分成了幾個(gè)小的片段segment,而且每個(gè)小的片段segment上面都有鎖存在,那麼在插入元素的時(shí)候就需要先找到應(yīng)該插入到哪一個(gè)片段segment,然後再在這個(gè)片段上面進(jìn)行插入,而且這裡還需要獲取segment鎖。

ConcurrentHashMap讓鎖定的粒度更精細(xì)一些,並發(fā)效能更好。

(推薦教學(xué):java入門教學(xué)

HashMap

HashMap是線程不安全的,在原始碼中對(duì)put方法沒有做鎖的處理,當(dāng)放生多線程時(shí),會(huì)有線程安全問題,下面通過一個(gè)簡(jiǎn)單的例子進(jìn)行演示,創(chuàng)建三個(gè)線程,並且啟動(dòng),在run方法里通過for循環(huán)給map存100個(gè)值,然後輸出map的大小以正常來說,該map的大小應(yīng)該是100,而這裡輸出了176。

class Demo implements Runnable{
    static Map<String,String> map = new HashMap<>();

    @Override
    public void run() {
        for (int i = 0; i < 100; i ++) {
            map.put(i + "","value");
        }
    }

    public static void main(String[] args) {

        new Thread(new Demo()).start();
        new Thread(new Demo()).start();
        new Thread(new Demo()).start();
        // 獲取當(dāng)前線程
        Thread currentThread = Thread.currentThread();
        // 當(dāng)前線程睡眠2秒,讓上面的三個(gè)線程先執(zhí)行
        try {
            currentThread.sleep(2000);
        } catch (Exception e) {
            e.getMessage();
        }
        // 上面的線程執(zhí)行完畢后輸出map的大小
        System.out.println(map.size());
    }
}

hashmap和concurrenthashmap的差別是什麼

HashTable

HashTable用到了鎖,而且是直接給put方法加的鎖,線程肯定是安全的了,這裡我們?cè)跍y(cè)試線程安全的同時(shí),看一下執(zhí)行時(shí)間,這裡透過put10000個(gè)資料進(jìn)行測(cè)試,透過結(jié)果可以看到,map的大小確實(shí)是10000,而時(shí)間用了16ms左右。

hashmap和concurrenthashmap的差別是什麼

class Demo implements Runnable{
    static Map<String,String> map = new Hashtable<>();

    @Override
    public void run() {
        long startTime = System.currentTimeMillis(); //獲取開始時(shí)間
        for (int i = 0; i < 10000; i ++) {
            map.put(i + "","value");
        }
        long endTime = System.currentTimeMillis(); //獲取結(jié)束時(shí)間
        System.out.println((endTime - startTime) + "ms");
    }

    public static void main(String[] args) {

        new Thread(new Demo()).start();
        new Thread(new Demo()).start();
        new Thread(new Demo()).start();
        // 獲取當(dāng)前線程
        Thread currentThread = Thread.currentThread();
        // 當(dāng)前線程睡眠2秒,讓上面的三個(gè)線程先執(zhí)行
        try {
            currentThread.sleep(2000);
        } catch (Exception e) {
            e.getMessage();
        }
        // 上面的線程執(zhí)行完畢后輸出map的大小
        System.out.println(map.size());
    }
}

hashmap和concurrenthashmap的差別是什麼

ConcurrentHashMap

ConcurrentHashMap用的是分段鎖,哪一塊不安全就鎖哪塊,不能不鎖,不能全鎖,那我就塊鎖!看看這個(gè)塊鎖相對(duì)於方法鎖是快了,還是慢了。

hashmap和concurrenthashmap的差別是什麼

class Demo implements Runnable{
    static Map<String,String> map = new ConcurrentHashMap<>();

    @Override
    public void run() {
        long startTime = System.currentTimeMillis(); //獲取開始時(shí)間
        for (int i = 0; i < 10000; i ++) {
            map.put(i + "","value");
        }
        long endTime = System.currentTimeMillis(); //獲取結(jié)束時(shí)間
        System.out.println((endTime - startTime) + "ms");
    }

    public static void main(String[] args) {

        new Thread(new Demo()).start();
        new Thread(new Demo()).start();
        new Thread(new Demo()).start();
        // 獲取當(dāng)前線程
        Thread currentThread = Thread.currentThread();
        // 當(dāng)前線程睡眠2秒,讓上面的三個(gè)線程先執(zhí)行
        try {
            currentThread.sleep(2000);
        } catch (Exception e) {
            e.getMessage();
        }
        // 上面的線程執(zhí)行完畢后輸出map的大小
        System.out.println(map.size());
    }
}

hashmap和concurrenthashmap的差別是什麼

從結(jié)果中看到,從先前的20ms和22ms提高到了現(xiàn)在的17ms和18ms

#更多電腦程式相關(guān)知識(shí),請(qǐng)?jiān)煸L:程式設(shè)計(jì)影片! !

以上是hashmap和concurrenthashmap的差別是什麼的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)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脫衣器

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整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
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

如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動(dòng)提交模式,再執(zhí)行多個(gè)操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務(wù);2.執(zhí)行多個(gè)SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時(shí)應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點(diǎn)實(shí)現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

在Java的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

了解Java虛擬機(jī)(JVM)內(nèi)部 了解Java虛擬機(jī)(JVM)內(nèi)部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當(dāng)前日期時(shí)間;3.使用of()方法創(chuàng)建特定日期時(shí)間;4.利用plus/minus方法不可變地增減時(shí)間;5.使用ZonedDateTime和ZoneId處理時(shí)區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時(shí)通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

Google Chrome無法打開本地文件 Google Chrome無法打開本地文件 Aug 01, 2025 am 05:24 AM

ChromecanopenlocalfileslikeHTMLandPDFsbyusing"Openfile"ordraggingthemintothebrowser;ensuretheaddressstartswithfile:///;2.SecurityrestrictionsblockAJAX,localStorage,andcross-folderaccessonfile://;usealocalserverlikepython-mhttp.server8000tor

了解網(wǎng)絡(luò)端口和防火牆 了解網(wǎng)絡(luò)端口和防火牆 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

比較Java框架:Spring Boot vs Quarkus vs Micronaut 比較Java框架:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

前形式攝取,quarkusandmicronautleaddueTocile timeProcessingandGraalvSupport,withquarkusoftenpernperforminglightbetterine nosserless notelless centarios.2。

See all articles