请问像ConcurrentHashMap等高性能的类具体的业务使用场景是哪些?

发布于 2022-09-05 03:57:44 字数 230 浏览 24 评论 0

如题,请问像ConcurrentHashMap等高性能的类具体的业务使用场景是哪些?

平时我们写代码的时候用得最多的一般是HashMap,也习以为常了

可是Java里有其他的高性能的Map,感觉平时也用不到

百度了一下,只看到了HashMap和ConcurrentHashMap的区别

却不晓得哪些具体的业务使用场景会用到这些类

因此感觉有些茫然,希望前辈能指导一下,谢谢

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(8

最近可好 2022-09-12 03:57:44

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() 就会有很多线程同时调用。

睫毛上残留的泪 2022-09-12 03:57:44

就想其它的答案已经回答的一样,ConcurrentHashMap主要是支持多线程的读写。因为要额外的操作,所以它的性能会低于普通的HashMap,而不是高于。

泅人 2022-09-12 03:57:44

ConcurrentHashMap是java.util.concurrent包下防止并发的工具类。业务使用时自己的并发类实现ThreadLocal也行。。。

主要用在多线程中,Java早些版本是使用synchronized同步块的方式,加锁释放等不易解决问题。而现在Java官方全都写好了,看看多线程就知道了。。。

业务场景就比如说公司的人员信息用多线程的方式入库,如果使用java.util.List就会有造成每个线程数据不一致的现象,这时就要用并发工具类了。主要注意 数据时,读数据就无所谓了。。。

‖放下 2022-09-12 03:57:44

谢邀。

你得先知道:

  • 在多线程对一个没有保护的对象执行操作会导致大家看到的状态不一致。

  • 你可以开几个线程对一个普通的hashMap去put,remove,前提是在一定条件下,比如里面元素符合一定要求,大于小于等于某个数之类的。

  • ConcurrentHashMap是jdk的并发包中提供的并发map,可以有效防止多线程操作一个对象时出现对象副本不一致。

场景的话百度可以搜一下。

2022-09-12 03:57:44

区别就不用说了.这些你应该都已经了解了.

为了保证线程安全,我们一般都是用Synchronize关键字,有了ConcurrentHashMap后,你可以不用再使用笨重的Synchronize方法了. 另外ConcurrentHashMap在多线程的情况下,也是一般用在读多写少的情况.不是所有的多线程都可以使用这个并发工具类的.

陌若浮生 2022-09-12 03:57:44

集合是可以是线程安全的(面试题刷题的时候经常遇到hashmap和hashtable的区别,所以在遇到多线程的时候第一反应是用hashtable),但是迭代器并不是,在多线程情况下,你要读取数据咋办呢,正在迭代的时候,结构发生了变化,
用ConcurrentHashMap

樱&纷飞 2022-09-12 03:57:44

其实很多,主要是对线程安全有要求的需求,比如对用户的单位时长访问频次限制这个需求。

岁吢 2022-09-12 03:57:44

Mark。面试的时候也被问过。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文