原文:http://www.java2000.net/p12427先看看代码吧,模拟1000个并发,每个测试1000次操作,循环测试10轮。分别测试Put和Get操作
- import java.util.Collections;
- import java.util.HashMap;
- import java.util.Hashtable;
- import java.util.Map;
- import java.util.concurrent.ConcurrentHashMap;
- public class T {
- static final int threads = 1000;
- static final int NUMBER = 1000;
- public static void main(String[] args) throws Exception {
- Map<String, Integer> hashmapSync = Collections
- .synchronizedMap(new HashMap<String, Integer>());
- Map<String, Integer> concurrentHashMap = new ConcurrentHashMap<String, Integer>();
- Map<String, Integer> hashtable = new Hashtable<String, Integer>();
- long totalA = 0;
- long totalB = 0;
- long totalC = 0;
- for (int i = 0; i <= 10; i++) {
- totalA += testPut(hashmapSync);
- totalB += testPut(concurrentHashMap);
- totalC += testPut(hashtable);
- }
- System.out.println("Put time HashMapSync=" + totalA + "ms.");
- System.out.println("Put time ConcurrentHashMap=" + totalB + "ms.");
- System.out.println("Put time Hashtable=" + totalC + "ms.");
- totalA = 0;
- totalB = 0;
- totalC = 0;
- for (int i = 0; i <= 10; i++) {
- totalA += testGet(hashmapSync);
- totalB += testGet(concurrentHashMap);
- totalC += testGet(hashtable);
- }
- System.out.println("Get time HashMapSync=" + totalA + "ms.");
- System.out.println("Get time ConcurrentHashMap=" + totalB + "ms.");
- System.out.println("Get time Hashtable=" + totalC + "ms.");
- }
- public static long testPut(Map<String, Integer> map) throws Exception {
- long start = System.currentTimeMillis();
- for (int i = 0; i < threads; i++) {
- new MapPutThread(map).start();
- }
- while (MapPutThread.counter > 0) {
- Thread.sleep(1);
- }
- return System.currentTimeMillis() - start;
- }
- public static long testGet(Map<String, Integer> map) throws Exception {
- long start = System.currentTimeMillis();
- for (int i = 0; i < threads; i++) {
- new MapPutThread(map).start();
- }
- while (MapPutThread.counter > 0) {
- Thread.sleep(1);
- }
- return System.currentTimeMillis() - start;
- }
- }
- class MapPutThread extends Thread {
- static int counter = 0;
- static Object lock = new Object();
- private Map<String, Integer> map;
- private String key = this.getId() + "";
- MapPutThread(Map<String, Integer> map) {
- synchronized (lock) {
- counter++;
- }
- this.map = map;
- }
- public void run() {
- for (int i = 1; i <= T.NUMBER; i++) {
- map.put(key, i);
- }
- synchronized (lock) {
- counter--;
- }
- }
- }
- class MapGetThread extends Thread {
- static int counter = 0;
- static Object lock = new Object();
- private Map<String, Integer> map;
- private String key = this.getId() + "";
- MapGetThread(Map<String, Integer> map) {
- synchronized (lock) {
- counter++;
- }
- this.map = map;
- }
- public void run() {
- for (int i = 1; i <= T.NUMBER; i++) {
- map.get(key);
- }
- synchronized (lock) {
- counter--;
- }
- }
- }
运行结果:
Put time HashMapSync=3966ms.
Put time ConcurrentHashMap=1892ms.
Put time Hashtable=3892ms.
Get time HashMapSync=3812ms.
Get time ConcurrentHashMap=1828ms.
Get time Hashtable=3985ms.
结论:
ConcurrentHashMap的性能比同步的HashMap快一倍左右
同步的HashMap和Hashtable的性能相当
分享到:
相关推荐
ConcurrentHashMap在Java 8中放弃了分段锁,改用ForkJoinPool和CAS(Compare And Swap)操作,提高了并发性能。初始化时,它会创建一个固定大小的数组,并在put过程中: 1. 初始化数组,包括计算初始大小和填充因子...
在Java编程语言中,`HashMap`和`ConcurrentHashMap`是两种非常重要的数据结构,它们都属于`java.util`包,用于存储键值对。本文将深入解析这两个类在Java 7和8版本中的实现原理、特点以及使用场景。 首先,`HashMap...
### HashMap和ConcurrentHashMap...综上所述,面试时通常会针对HashMap和ConcurrentHashMap的实现原理、它们的差异、以及在并发环境下如何保证数据的一致性和线程安全进行提问。了解这些知识点有助于在面试中脱颖而出。
HashMap和ConcurrentHashMap的区别 HashMap和ConcurrentHashMap是Java语言中两个常用的哈希表实现,它们都继承自AbstractMap类,实现了Map接口,但是它们之间存在着一些关键的区别。 首先,从数据结构上讲,...
在Java编程中,Map接口是用于存储键值对的数据结构,而Java提供了多种Map的实现,包括TreeMap、HashMap和ConcurrentSkipListMap。...在实际使用中,应结合性能测试和业务需求来确定最适合的Map类型。
ConcurrentHashMap在Java 8中也进行了优化,取消了分段锁,改用ForkJoinPool和CAS操作,实现更为细粒度的并发控制,进一步提升了并发性能。 对于Java 8的ConcurrentHashMap,其内部结构更为复杂,使用了Node节点...
这种改进是为了在空间和性能之间取得更好的平衡。 ConcurrentHashMap 则采用了分段锁的设计,它将整个映射表分成多个段(Segment),每个段都是一个独立的 HashMap 实例,并且每个段有自己的锁。这种方式允许并发的...
ConcurrentHashMap 使用了分段锁的机制,每个段都独立锁定,提高了并发性能。 HashMap 和 HashTable 的区别 1. 线程安全性:HashMap 是非线程安全的,HashTable 是线程安全的。 2. 键和值的 null 值:HashMap 的键...
本题旨在考察候选人在实际并发场景下对 HashMap 和 ConcurrentHashMap 的理解和应用。 HashMap 和 ConcurrentHashMap 的主要区别在于它们对并发操作的支持。HashMap 是非线程安全的,意味着在多线程环境中,如果不...
Java并发编程中的ConcurrentHashMap是HashMap的一个线程安全版本,设计目标是在高并发场景下提供高效的数据访问。相比HashTable,ConcurrentHashMap通过采用锁分离技术和更细粒度的锁定策略来提升性能。HashTable...
总的来说,ConcurrentHashMap是Java并发编程中的重要组件,通过高效的并发控制策略和优化的数据结构,实现了在高并发场景下的高效并发访问。了解并掌握其原理对于提升Java并发编程能力至关重要。
总的来说,理解`HashMap`和`ConcurrentHashMap`的工作原理以及它们在性能上的差异,对于优化Java程序的运行效率和并发性能至关重要。开发者可以根据实际情况,选择最适合的数据结构,以实现更高效、更稳定的应用。
在Java的HashMap中,多线程并发环境...总之,理解HashMap的扩容机制和潜在的问题对于编写高性能、线程安全的Java程序至关重要。在多线程环境下,合理选择数据结构和同步策略可以避免这类问题,确保程序的稳定性和效率。
尽管它们在功能上有很多相似之处,但在实现细节和性能特性上存在显著差异。 #### 二、主要区别 1. **空值支持**: - **HashMap**:允许使用 `null` 键和 `null` 值。 - **HashTable**:不允许使用 `null` 键或 `...
【并发容器的线程安全性】与`HashMap`不同,`ConcurrentHashMap`通过采用非阻塞算法(如CAS操作)和分段锁机制来保证并发性能,避免了整个表的锁定,提高了在多线程环境下的并发性和性能。 【存储结构】`...
总的来说,`ConcurrentHashMap`的设计是为了解决多线程环境下HashMap的线程安全问题,通过分段锁和CAS操作实现了高效并发的哈希表。从JDK1.7到1.8的演变,反映了并发编程中对性能和线程安全的不断追求。
通过以上分析,我们可以看到ConcurrentHashMap如何通过锁分段技术来解决HashMap在并发环境下的线程安全问题,并通过巧妙的设计减少线程间锁的竞争,从而提升性能。因此,在设计需要高并发性能的程序时,...
HashMap适用于单线程环境,提供快速的插入和查找,而ConcurrentHashMap在多线程环境下保证了线程安全和高并发性能。理解它们的内部工作原理对于优化代码性能和避免并发问题至关重要。在实际开发中,根据具体场景选择...
面试中,可能会被问及HashMap的性能优化、内存占用分析、以及在特定场景下的选择,如并发环境、内存敏感的应用等。 总结,HashMap是Java编程中的基础工具,掌握其工作原理和常见面试题,不仅能帮助我们应对面试,更...