java - 請問像ConcurrentHashMap等高性能的類具體的業務使用場景是哪些?
問題描述
如題,請問像ConcurrentHashMap等高性能的類具體的業務使用場景是哪些?
平時我們寫代碼的時候用得最多的一般是HashMap,也習以為常了
可是Java里有其他的高性能的Map,感覺平時也用不到
百度了一下,只看到了HashMap和ConcurrentHashMap的區別
卻不曉得哪些具體的業務使用場景會用到這些類
因此感覺有些茫然,希望前輩能指導一下,謝謝
問題解答
回答1:ConcurrentHashMap是java.util.concurrent包下防止并發的工具類。業務使用時自己的并發類實現ThreadLocal也行。。。
主要用在多線程中,Java早些版本是使用synchronized同步塊的方式,加鎖釋放等不易解決問題。而現在Java官方全都寫好了,看看多線程就知道了。。。
業務場景就比如說公司的人員信息用多線程的方式入庫,如果使用java.util.List就會有造成每個線程數據不一致的現象,這時就要用并發工具類了。主要注意 寫 數據時,讀數據就無所謂了。。。
回答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() 就會有很多線程同時調用。
回答3:謝邀。
你得先知道:
在多線程對一個沒有保護的對象執行操作會導致大家看到的狀態不一致。
你可以開幾個線程對一個普通的hashMap去put,remove,前提是在一定條件下,比如里面元素符合一定要求,大于小于等于某個數之類的。
ConcurrentHashMap是jdk的并發包中提供的并發map,可以有效防止多線程操作一個對象時出現對象副本不一致。
場景的話百度可以搜一下。
回答4:區別就不用說了.這些你應該都已經了解了.
為了保證線程安全,我們一般都是用Synchronize關鍵字,有了ConcurrentHashMap后,你可以不用再使用笨重的Synchronize方法了. 另外ConcurrentHashMap在多線程的情況下,也是一般用在讀多寫少的情況.不是所有的多線程都可以使用這個并發工具類的.
相關文章:
1. docker安裝后出現Cannot connect to the Docker daemon.2. 為什么我ping不通我的docker容器呢???3. android - webview 自定義加載進度條4. mysql - 怎么讓 SELECT 1+null 等于 15. javascript - 微信音樂分享6. 網頁爬蟲 - 用Python3的requests庫模擬登陸Bilibili總是提示驗證碼錯誤怎么辦?7. javascript - 微信小程序封裝定位問題(封裝異步并可能多次請求)8. 并發模型 - python將進程池放在裝飾器里為什么不生效也沒報錯9. linux - openSUSE 上,如何使用 QQ?10. python 怎樣用pickle保存類的實例?
