遇到这么一个问题,后台多线程执行一个长时间的大量的任务,前台通过轮训查询任务进度。
任务进度放在一个 ConcurrentHashMap 中,然后每个线程执行完一次任务就在这个 map 里面的 index+1。然后这个 map 再放在另一个静态的 ConcurrentHashMap 里面,key 是批次号。
然后前台查询任务进度的时候是这样:静态的 map.get(批次号).get(index)得到已经完成的任务数。
也就是说外面那个 map 存储的是里面 map 的引用,然后里面 map 的内容一直在变化。但是前端查询进度的时候,得到的数字一直是 0。
外面 map 换成 HashMap 之后问题消失,有点好奇这里是不是跟 ConcurrentHashMap 的特性有关?是不是存储引用的时候会保存一个副本之类的?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.