前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >大数据必学Java基础(六十二):ConcurrentMap并发容器对比

大数据必学Java基础(六十二):ConcurrentMap并发容器对比

原创
作者头像
Lansonli
发布2022-10-01 00:15:37
发布2022-10-01 00:15:37
31900
代码可运行
举报
文章被收录于专栏:Lansonli技术博客Lansonli技术博客
运行总次数:0
代码可运行

​ConcurrentMap并发容器对比

JDK5.0之后提供了多种并发类容器可以替代同步类容器,提升性能、吞吐量

ConcurrentHashMap替代HashMap、HashTable

ConcurrentSkipListMap替代TreeMap

简单原理:

并发情况下,验证提高性能

一、ConcunrrentHashMap

代码语言:javascript
代码运行次数:0
运行
复制
public class Test {
    //这是main方法,程序的入口
    public static void main(String[] args) {
        //选择一个容器:
        ConcurrentHashMap<String,Integer> map = new ConcurrentHashMap<>();
        
        //创建10个线程:
        for (int i = 0; i < 10; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    long startTime = System.currentTimeMillis();
                    for (int j = 0; j < 1000000; j++) {
                        map.put("test" + j , j);
                    }
                    long endTime = System.currentTimeMillis();
                    System.out.println("一共需要的时间:" + (endTime - startTime));
                }
            }).start();
        }
    }
}

结果:

二、Hashtable

代码语言:javascript
代码运行次数:0
运行
复制
package com.lanson.test03;

import java.util.Hashtable;
import java.util.concurrent.ConcurrentHashMap;

/**
 * @author : lanson
 */
public class Test {
    //这是main方法,程序的入口
    public static void main(String[] args) {
        //选择一个容器:
        //ConcurrentHashMap<String,Integer> map = new ConcurrentHashMap<>();
        Hashtable map = new Hashtable();
        //创建10个线程:
        for (int i = 0; i < 10; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    long startTime = System.currentTimeMillis();
                    for (int j = 0; j < 1000000; j++) {
                        map.put("test" + j , j);
                    }
                    long endTime = System.currentTimeMillis();
                    System.out.println("一共需要的时间:" + (endTime - startTime));
                }
            }).start();
        }
    }
}

结果:

三、HashMap

代码语言:javascript
代码运行次数:0
运行
复制
package com.lanson.test03;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.concurrent.ConcurrentHashMap;

/**
 * @author : lanson
 */
public class Test {
    //这是main方法,程序的入口
    public static void main(String[] args) {
        //选择一个容器:
        //ConcurrentHashMap<String,Integer> map = new ConcurrentHashMap<>();
        //Hashtable map = new Hashtable();
        HashMap map = new HashMap();
        //创建10个线程:
        for (int i = 0; i < 10; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    long startTime = System.currentTimeMillis();
                    for (int j = 0; j < 1000000; j++) {
                        map.put("test" + j , j);
                    }
                    long endTime = System.currentTimeMillis();
                    System.out.println("一共需要的时间:" + (endTime - startTime));
                }
            }).start();
        }
    }
}

结果:

四、线程安全的HashMap

代码语言:javascript
代码运行次数:0
运行
复制
package com.lanson.test03;

import java.util.Collections;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

/**
 * @author : lanson
 */
public class Test {
    //这是main方法,程序的入口
    public static void main(String[] args) {
        //选择一个容器:
        //ConcurrentHashMap<String,Integer> map = new ConcurrentHashMap<>();
        //Hashtable map = new Hashtable();
        HashMap oldmap = new HashMap();
        Map map = Collections.synchronizedMap(oldmap);
        //创建10个线程:
        for (int i = 0; i < 10; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    long startTime = System.currentTimeMillis();
                    for (int j = 0; j < 1000000; j++) {
                        map.put("test" + j , j);
                    }
                    long endTime = System.currentTimeMillis();
                    System.out.println("一共需要的时间:" + (endTime - startTime));
                }
            }).start();
        }
    }
}

结果:

五、总结

ConcurrentHashMap:性能高,线程安全

Hashtable: 线程安全,性能低

HashMap:线程不安全,性能高

线程安全的HashMap:线程安全,性能低

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • ​ConcurrentMap并发容器对比
    • 一、ConcunrrentHashMap
    • 二、Hashtable
    • 三、HashMap
    • 四、线程安全的HashMap
    • 五、总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档