7 回答
TA贡献1851条经验 获得超5个赞
区别就不用说了.这些你应该都已经了解了.
为了保证线程安全,我们一般都是用Synchronize关键字,有了ConcurrentHashMap后,你可以不用再使用笨重的Synchronize方法了. 另外ConcurrentHashMap在多线程的情况下,也是一般用在读多写少的情况.不是所有的多线程都可以使用这个并发工具类的.
TA贡献1871条经验 获得超13个赞
集合是可以是线程安全的(面试题刷题的时候经常遇到hashmap和hashtable的区别,所以在遇到多线程的时候第一反应是用hashtable),但是迭代器并不是,在多线程情况下,你要读取数据咋办呢,正在迭代的时候,结构发生了变化,
用ConcurrentHashMap
TA贡献2011条经验 获得超2个赞
ConcurrentHashMap 专门是给多个线程访问的。举个例子:
// 在线用户管理类
public class UserManager {
private Map<String, User> userMap = new ConcurrentHashMap<>();
// 当用户登入时调用
public void onUserSignIn(String sessionId, User user) {
this.userMap.put(sessionId, user);
}
// 当用户登出或超时时调用
public void onUserSignOut(String sessionId) {
this.userMap.remove(sessionId);
}
public getUser(String sessionId) {
return this.userMap.get(sessionId);
}
}
当有很多用户同时登入和登出时,onUserSignIn()
和 onUserSignOut()
就会有很多线程同时调用。
TA贡献1895条经验 获得超7个赞
就想其它的答案已经回答的一样,ConcurrentHashMap主要是支持多线程的读写。因为要额外的操作,所以它的性能会低于普通的HashMap,而不是高于。
TA贡献1797条经验 获得超6个赞
ConcurrentHashMap是java.util.concurrent包下防止并发的工具类。业务使用时自己的并发类实现ThreadLocal也行。。。
主要用在多线程中,Java早些版本是使用synchronized同步块的方式,加锁释放等不易解决问题。而现在Java官方全都写好了,看看多线程就知道了。。。
业务场景就比如说公司的人员信息用多线程的方式入库,如果使用java.util.List就会有造成每个线程数据不一致的现象,这时就要用并发工具类了。主要注意 写
数据时,读数据就无所谓了。。。
添加回答
举报