import java.util.ArrayList;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Random;
import java.util.Vector;
import java.util.concurrent.ConcurrentHashMap;
public class Main {
static ConcurrentHashMap table = new ConcurrentHashMap();
public static void main(String[] args) throws InterruptedException {
table.put("1", "1");
System.out.println("loading success");
new Thread() {
@Override
public void run() {
try {
sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
table.remove("1");
}
}.start();
for(Iterator it=table.entrySet().iterator();it.hasNext();) {
Thread.sleep(2000);
System.out.println("hahahah");
Map.Entry entry=(Map.Entry)it.next();
System.out.println(entry.getKey());
System.out.println(entry.getValue());
table.remove(entry.getKey());
}
System.out.println("main thread compleat");
}
}
以上这段代码在惠普UNIX上面的结果比较特殊,是:
BimsInt2[/]#java Main
loading success
hahahah
1
null
main thread compleat
但是在windows、solaris和linux上面的结果是:
loading success
hahahah
1
1
main thread compleat
另:java里面的new java.util.Date()在惠普UNIX上面也比较特殊,具体不细说了。
分享到:
相关推荐
java源码剖析-ConcurrentHashMap
ConcurrentHashMap源码剖析
Java利用ConcurrentHashMap实现本地缓存demo; 基本功能有缓存有效期、缓存最大数、缓存存入记录、清理线程、过期算法删除缓存、LRU算法删除、获取缓存值等功能。 复制到本地项目的时候,记得改包路径哦~
源码分析见我博文:http://blog.csdn.net/wabiaozia/article/details/50684556
HashTable是一个线程安全的类,它使用synchronized来锁住整张Hash表来实现线程安全,即每次锁住整张表让线程独占,相当于所有线程进行读写时都去竞争一把锁...只要多个修改操作发生在不同的段上,它们就可以并发进行。
ConcurrentHashMap具体是怎么实现线程安全的呢,肯定不可能是每个方法加synchronized,那样就变成了HashTable。
这时候ConcurrentHashMap达到容量扩容而忽略了ReservationNode情况,调用put的时候在synchronized(f)没有对ReservationNode处理,所以会出现死循环。 在jdk1.8和1.9中对比 http://gee.cs.oswego.edu/cgi- bin/...
解析concurrenthashmap的源码,学习多线程的思想
本文将结合Java内存模型,分析JDK源代码,探索ConcurrentHashMap高并发的具体实现机制,包括其在JDK中的定义和结构、并发存取、重哈希和跨段操作,并着重剖析了ConcurrentHashMap读操作不需要加锁和分段锁机制的内在...
程序员面试加薪必备_ConcurrentHashMap底层原理与源码分析深入详解
java本地缓存ConcurrentHashMap
需要注意的是,在使用ConcurrentHashMap时,并发更新和迭代操作可能会导致一些问题,因为在操作过程中其他线程可能会修改数据。因此,如果需要保证精确的操作顺序或避免并发更新带来的问题,可以考虑使用更高级的...
ConcurrentHashMap之实现细节
concurrenthashmap1.7的源码分析
ConcurrentHashMap的实现原理(JDK1.7和JDK1.8),并说明了在jdk1.7与jdk1.8的不同实现原理
ConcurrentHashMap可以做到读取数据不加锁,并且其内部的结构可以让其在进行写操作的时候能够将锁的粒度保持地尽量地小,不用对整个ConcurrentHashMap加锁。ConcurrentHashMap为了提高本身的并发能力,在内部采用了...
Java——并发容器之ConcurrentHashMap;Java——并发容器之ConcurrentHashMap;Java——并发容器之ConcurrentHashMap;Java——并发容器之ConcurrentHashMap;Java——并发容器之ConcurrentHashMap;Java——并发...
java7-8中的 HashMap和ConcurrentHashMap全解析
ConcurrentHashMap的实现原理(纯干货)
Java并发编程之ConcurrentHashMap Java并发编程之ConcurrentHashMap.pdf