org.gridkit.jvmtool.stacktrace.RotatingStringDictionary Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sjk-stacktrace Show documentation
Show all versions of sjk-stacktrace Show documentation
Thread dumps: capture and encoding
package org.gridkit.jvmtool.stacktrace;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map;
/**
* Utility class used for dictionary with expiring entries.
*
* @author Alexey Ragozin ([email protected])
*/
class RotatingStringDictionary {
private Map dic = new LinkedHashMap();
private int limit;
public RotatingStringDictionary(int limit) {
this.limit = limit;
}
public boolean contains(String str) {
return dic.containsKey(str);
}
public int intern(String str) {
Integer id = dic.remove(str);
if (id != null) {
dic.put(str, id);
return id;
}
else {
if (dic.size() == limit) {
Iterator v = dic.values().iterator();
id = v.next();
v.remove();
dic.put(str, id);
return ~id;
}
else {
id = dic.size();
dic.put(str, id);
return ~id;
}
}
}
}