java - 請問像ConcurrentHashMap等高性能的類具體的業(yè)務(wù)使用場景是哪些?
問題描述
如題,請問像ConcurrentHashMap等高性能的類具體的業(yè)務(wù)使用場景是哪些?
平時我們寫代碼的時候用得最多的一般是HashMap,也習(xí)以為常了
可是Java里有其他的高性能的Map,感覺平時也用不到
百度了一下,只看到了HashMap和ConcurrentHashMap的區(qū)別
卻不曉得哪些具體的業(yè)務(wù)使用場景會用到這些類
因此感覺有些茫然,希望前輩能指導(dǎo)一下,謝謝
問題解答
回答1:ConcurrentHashMap是java.util.concurrent包下防止并發(fā)的工具類。業(yè)務(wù)使用時自己的并發(fā)類實(shí)現(xiàn)ThreadLocal也行。。。
主要用在多線程中,Java早些版本是使用synchronized同步塊的方式,加鎖釋放等不易解決問題。而現(xiàn)在Java官方全都寫好了,看看多線程就知道了。。。
業(yè)務(wù)場景就比如說公司的人員信息用多線程的方式入庫,如果使用java.util.List就會有造成每個線程數(shù)據(jù)不一致的現(xiàn)象,這時就要用并發(fā)工具類了。主要注意 寫 數(shù)據(jù)時,讀數(shù)據(jù)就無所謂了。。。
回答2:ConcurrentHashMap 專門是給多個線程訪問的。舉個例子:
// 在線用戶管理類public class UserManager { private Map<String, User> userMap = new ConcurrentHashMap<>();// 當(dāng)用戶登入時調(diào)用 public void onUserSignIn(String sessionId, User user) {this.userMap.put(sessionId, user); }// 當(dāng)用戶登出或超時時調(diào)用 public void onUserSignOut(String sessionId) {this.userMap.remove(sessionId); }public getUser(String sessionId) {return this.userMap.get(sessionId); }}
當(dāng)有很多用戶同時登入和登出時,onUserSignIn() 和 onUserSignOut() 就會有很多線程同時調(diào)用。
回答3:謝邀。
你得先知道:
在多線程對一個沒有保護(hù)的對象執(zhí)行操作會導(dǎo)致大家看到的狀態(tài)不一致。
你可以開幾個線程對一個普通的hashMap去put,remove,前提是在一定條件下,比如里面元素符合一定要求,大于小于等于某個數(shù)之類的。
ConcurrentHashMap是jdk的并發(fā)包中提供的并發(fā)map,可以有效防止多線程操作一個對象時出現(xiàn)對象副本不一致。
場景的話百度可以搜一下。
回答4:區(qū)別就不用說了.這些你應(yīng)該都已經(jīng)了解了.
為了保證線程安全,我們一般都是用Synchronize關(guān)鍵字,有了ConcurrentHashMap后,你可以不用再使用笨重的Synchronize方法了. 另外ConcurrentHashMap在多線程的情況下,也是一般用在讀多寫少的情況.不是所有的多線程都可以使用這個并發(fā)工具類的.
相關(guān)文章:
1. objective-c - ios百度地圖定位問題2. html - css 如何添加這種邊框?3. javascript - 求助這種功能有什么好點(diǎn)的插件?4. html5 - 如何解決bootstrap打開模態(tài)modal窗口引起頁面抖動?5. javascript - 求助關(guān)于js正則問題6. javascript - node.js服務(wù)端渲染解疑7. html5 - rudy編譯sass的時候有中文報錯8. javascript - 關(guān)于定時器 與 防止連續(xù)點(diǎn)擊 問題9. 為何 localStorage、sessionStorage 屬于html5的范疇,但是為何 IE8卻支持?10. 微信開放平臺 - Android調(diào)用微信分享不顯示
