[Java] HashMap 导致的高 CPU 使用率

 今天在生产环境遇到一个问题,Java 应用程序的 cpu 使用比例很高,导致整台机器的 cpu 使用率高达 90% ,正常情况下是 20% 左右。

把 Thread dump 导出来,利用 IBM Thread Analyzer for Java 工具进行分析。总共有60 多个在线线程,其中有 15 个线程都在执行同一个文件中的同一句代码,最顶层的调用是 HashMap.get() 。

HashMap 的底层数据结构是数组 + 链表进行存储,链表用于处理 hash 碰撞的情况。正常情况下链接是线性链表,当数据结构在并发情况下被污染了,导致出现环形链表,则会出现程序的无限循环。

15 个线程在同一时间都在执行同一行代码,是很不正常的情况。当线程调用 HashMap.get 并在链表上搜索时,碰巧遇到的是被污染的环形链接,就能解释得通这个异常情况了。

HashMap 是非线程安全,在多线程并发访问时,有可能出现环形链表。详细且清晰的分析,参考:

A Beautiful Race Condition

Explain the timing causing HashMap.put() to execute an infinite loop

 

附:关于 HashMap 源码阅读笔记

Map / HashMap - 源代码学习笔记

转载于:https://www.cnblogs.com/TonyYPZhang/p/6041312.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值