7 回答

TA貢獻1851條經驗 獲得超5個贊
區(qū)別就不用說了.這些你應該都已經了解了.
為了保證線程安全,我們一般都是用Synchronize關鍵字,有了ConcurrentHashMap后,你可以不用再使用笨重的Synchronize方法了. 另外ConcurrentHashMap在多線程的情況下,也是一般用在讀多寫少的情況.不是所有的多線程都可以使用這個并發(fā)工具類的.

TA貢獻1871條經驗 獲得超13個贊
集合是可以是線程安全的(面試題刷題的時候經常遇到hashmap和hashtable的區(qū)別,所以在遇到多線程的時候第一反應是用hashtable),但是迭代器并不是,在多線程情況下,你要讀取數據咋辦呢,正在迭代的時候,結構發(fā)生了變化,
用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包下防止并發(fā)的工具類。業(yè)務使用時自己的并發(fā)類實現ThreadLocal也行。。。
主要用在多線程中,Java早些版本是使用synchronized同步塊的方式,加鎖釋放等不易解決問題。而現在Java官方全都寫好了,看看多線程就知道了。。。
業(yè)務場景就比如說公司的人員信息用多線程的方式入庫,如果使用java.util.List就會有造成每個線程數據不一致的現象,這時就要用并發(fā)工具類了。主要注意 寫
數據時,讀數據就無所謂了。。。
添加回答
舉報