我正在尝试使用JSP在页面上显示5000条记录。但我失去了内存异常。我这样做,
<TABLE><tr><td>Header1</td><td>Header2</td><td>Header3</td><td>Header4</td><td>Header5</td></tr>");
<%Test test = new Test();
List myList = test.fetchdata();
Iterator itr = myList.iterator();
while(itr.hasNext())
{
Object[] row = (Object[]) itr.next();
String hdr1 = (String) row[0];
String hdr2 = (String) row[1];
String hdr3 = (String) row[2];
String hdr4 = (String) row[3];
String hdr5 = (String) row[4];
stringBuilder.append"<tr><td>'"+hdr1+"'</td><td>'"+hdr2+"'</td><td>'"+hdr3+"'</td><td>'"+hdr4+"'</td><td>'"+hdr5+"'</td></tr>");
}
stringBuilder.append("</TABLE></body></html>");
out.print(stringBuilder.toString());
%>
1)如果我想决定在屏幕上保留5000条记录,我的代码是否有任何错误
2)或者如果我使用分页等,这个错误会发生吗?
答案 0 :(得分:1)
因为您的代码示例以某种方式被破坏,所以很难说,但有两个地方会导致内存问题。 A)你的test.fetchdata() B)你追加到StringBuilder
从B开始,如果你直接在JSP上,你可以尝试直接输出它,而不是使用StringBuilder。根据JSP编译器的不同,它可能会生成不占用大量内存的较小的StringBuilder。
但很可能问题出现在答案中。你得到一个已经占据很多记忆的长名单。 你只能通过做一些延迟加载的结果(在迭代器中)或者你通过分页提出自己来优化(这是值得推荐的,因为所有注释都表明:-))
当有许多重复的字符串时,最后一个选项可能值得尝试。在将String存储在数组中之前,fetchdata()方法内部使用.intern()。这可以防止多个相同的字符串占用额外的堆,但需要花费一点时间来计算它。
答案 1 :(得分:0)
我正在考虑添加更多这样的东西。
List myList = test.fetchdata();
Iterator itr = myList.iterator();
StringBuilder stringBuilder = new StringBuilder("");
while (itr.hasNext()) {
Object[] row = (Object[]) itr.next();
String hdr1 = (String) row[0];
String hdr2 = (String) row[1];
String hdr3 = (String) row[2];
String hdr4 = (String) row[3];
String hdr5 = (String) row[4];
stringBuilder.append("<tr><td>'").append(hdr1)
.append("'</td><td>'").append(hdr2).append("'</td><td>'")
.append(hdr3).append("'</td><td>'").append(hdr4)
.append("'</td><td>'").append(hdr5).append("'</td></tr>");
}
stringBuilder.append("</TABLE></body></html>");
out.print(stringBuilder.toString());
或者可能将其重构为此。
List myList = test.fetchdata();
Iterator itr = myList.iterator();
StringBuilder stringBuilder = new StringBuilder("");
while (itr.hasNext()) {
Object[] row = (Object[]) itr.next();
stringBuilder.append("<tr><td>'").append(row[0])
.append("'</td><td>'").append(row[1]).append("'</td><td>'")
.append(row[2]).append("'</td><td>'").append(row[3])
.append("'</td><td>'").append(row[4]).append("'</td></tr>");
}
stringBuilder.append("</TABLE></body></html>");
out.print(stringBuilder.toString());