关于Java中的Map,已有很多文章讲述其较为完整的知识点了,本文不会再谈论这些知识点,而是从实际使用的角度,讲述笔者会考虑什么问题,算是对知识的一个应用,毕竟学了,最后还是要落地到使用中。
首先,在使用Map前,我们先考虑第一个问题,为什么要使用Map这种数据结构。在工作中,笔者会想到使用到Map的场景通常有:
在确认要使用Map后,便需要考虑使用哪种Map。通常最先想到,也最常用的是HashMap。但需要注意两个地方,是否对线程安全、有序性有要求。
线程安全:
有序性:
如果对有序性和线程安全同时有要求,那么需注意TreeMap和LinkedHashMap都不是线程安全的。对于TreeMap,可以使用Collections.synchronizedSortedMap 、synchronized和锁等方法来同步。同样LinkedHashMap,也可以使用Collections.synchronizedMap 、synchronized和锁来保证线程安全。
下面再进一步讨论对于使用HashMap的情况,如果是准备作为缓存来使用,且希望缓存可以自动清理,则可以使用WeakHashMap。
确定了Map的类型,最后会考虑的是,是否需要指定初始化大小。
在使用HashMap、ConcurrentHashMap和LinkedHashMap时,如果我们能预先知道存放元素的数量,则可以根据下面的公式计算出初始化大小并传入构造函数中,从而避免不必要的扩容。
总结:
以上就是笔者目前在使用Map时,会去考虑的一些事项,还有什么需要考虑的,欢迎留言讨论。
本文转载自微信公众号「 草捏子」,可以通过以下二维码关注。转载本文请联系 草捏子公众号。
名称栏目:使用Map时,需要考虑什么
链接地址:http://www.mswzjz.cn/qtweb/news20/479520.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能