我正在尝试使用包含大约 12000 条记录的数据库填充类型为 tableList 的数组列表,然后使用 struts 迭代器标记填充我的 jsp 页面,但是在一次又一次地执行此操作时,jvm 内存不足,正如我所见每次从我的页面调用此操作时,堆大小都会不断减小。我认为,每当创建此操作类的新实例时,列表空间都不会被释放。建议解决此问题。我也在运行 tableList.clear( ); 在类的构造函数中
int records=0;
spl("BEFORE: "+run.freeMemory()+"-"+run.totalMemory()+"-"+run.maxMemory());//spl is for system.out.println and run is an object of Runtime class
while(resultSet.next())
{
records++;
if(!resultSet.getString("service_date").equals("N/A"))
{
serviceYear=resultSet.getString("service_date").split("-");
regnNumber=officeCode+"/"+resultSet.getString("serviceid_requested")+"/"+resultSet.getString("country_code")+"/"+resultSet.getString("service_file_srno")+"/"+serviceYear[2];
}
else
{
regnNumber=officeCode+"/"+resultSet.getString("serviceid_requested")+"/"+resultSet.getString("country_code")+"/"+resultSet.getString("service_file_srno")+"/0000";
}
tableList.add(new MISTable(regnNumber,resultSet.getString("given_name"),resultSet.getString("surname"),
resultSet.getString("nationality"),resultSet.getString("service_date"),resultSet.getString("service_expiry_date"),
resultSet.getString("passport_number"),resultSet.getString("passport_expiry_date"),resultSet.getString("visa_number"),
resultSet.getString("visa_expiry_date"),resultSet.getString("visa_type"),"")
);
}
spl("AFTER: "+run.freeMemory()+"-"+run.totalMemory()+"-"+run.maxMemory());