[英]memory leakage in this code?
private ArrayList<HashMap<String, String>> sortArrayMap(ArrayList arrList)
{
ArrayList retArray = new ArrayList();
Hashtable tableUnOrdered = new Hashtable();
for (int i = 0; i < arrList.size(); i++)
{
HashMap<String, String> map = (HashMap<String, String>) arrList.get(i);
tableUnOrdered.put(map.get("TCNT"), i);
}
Vector v = new Vector(tableUnOrdered.keySet());
Collections.sort(v);
for (int j = 0; j < MAX_ITEMS_PER_GRAPH && j < v.size(); j++)
retArray.add(v.get(j)); // add the list in the needed order
return retArray;
}
我无法找出此代码中发生内存泄漏的地方,任何人都可以让我知道这一点。 我的老板说此代码存在内存泄漏,请我找出来。
据我所知,此方法在某些封闭的类字段中未保存引用,因此不会导致内存泄漏。
除了参数之外,所有变量都位于方法范围内。 当方法终止时,它们将被标记为垃圾回收。
询问老板是否真的意味着内存泄漏,或者他是否意味着使用了过多的内存。 告诉他有很大的不同,您需要知道他担心的是哪一个。
坏了:我清理了泛型,并且没有返回HashMaps列表,而是返回了字符串列表。
private ArrayList<HashMap<String, String>> sortArrayMap2(ArrayList<HashMap<String, String>> arrList)
{
ArrayList<HashMap<String, String>> retArray = new ArrayList<HashMap<String, String>>();
HashMap<String, Integer> tableUnOrdered = new HashMap<String,Integer>();
for (int i = 0; i < arrList.size(); i++)
{
HashMap<String, String> map = arrList.get(i);
tableUnOrdered.put(map.get("TCNT"), i);
}
Vector<String> v = new Vector<String>(tableUnOrdered.keySet());
Collections.sort(v);
for (int j = 0; j < MAX_ITEMS_PER_GRAPH && j < v.size(); j++)
retArray.add(v.get(j)); // add the list in the needed order
return retArray;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.