我有以下地图-
ConcurrentHashMap histogram = new ConcurrentHashMap();
该映射包含许多键值对.将AtomicLong设置为值是必要的,因此这就是我在该图中这样放置的原因.
因此,现在如果我要遍历上面提到的ConcurrentHashMap,它总是在这行上给我错误-
buckets[i] += histogram.get(time);
as-对于参数类型int,AtomicLong未定义运算符=
我不确定如何解决此问题?我无法返回并将数据结构更改为所有Integer而不是Long和AtomicLong.
因此,我需要找出如何在以下代码中进行更改,以使其开始起作用.我当时想转换为整数.但是它也不起作用.
下面是我的代码
private static void logHistogramInfo() {
System.out.println("From Main Thread: " + histogram);
int[] definition = { 0, 20, 40, 60, 80, 100 };
int[] buckets = new int[definition.length];
for (Long time : histogram.keySet()) {
for (int i = definition.length - 1; i >= 0; i--) {
if (time >= definition[i]) {
//error on the below line
buckets[i] += histogram.get(time);
break;
}
}
}
for (int i = 0; i < definition.length; i++) {
String period = "";
if (i == definition.length - 1) {
period = "greater than " + definition[i] + "ms";
} else {
period = "between " + (definition[i] + 1) + " and " + definition[i + 1] + "ms";
}
System.out.println(buckets[i] + " came back " + period);
}
}