此代码块的并发修改异常,请帮助?
Concurrent Modification exception for this code block, Help Please?
missedMSRB 是一个包含 2187 个元素的列表,当尝试 运行 下面的代码片段时
List<List<String>> subList = getSubList(missedMSRB, 1000);
for (List<String> subMSRB : subList) {
StringBuffer sql = new StringBuffer(NamedQueries.msSQL);
sql.append("(");
for (int i1 = 0; i1 < subMSRB.size(); i1++) { //Line 463 Throws Exception
if (i1 < subMSRB.size() - 1) {
sql.append("?,");
} else {
sql.append("? )");
}
} ....
代码失败并出现以下异常任何建议我为什么得到并发修改以及如何摆脱相同的
13 Jan 2015 10:42:58,974 [main] ERROR RunAnalytics: General Error: null
java.util.ConcurrentModificationException
at java.util.ArrayList$SubList.checkForComodification(ArrayList.java:1169)
at java.util.ArrayList$SubList.size(ArrayList.java:998)
at com.abc.Analytics.RunAnalytics.getCountCheck(RunAnalytics.java:463)
at com.abc.Analytics.RunAnalytics.analyticsExecute(RunAnalytics.java:342)
at com.abc.Analytics.RunAnalytics.main(RunAnalytics.java:84)
下方剩余代码
PreparedStatement psMSQL2 = msSQL.prepareStatement(sql.toString());
psMSQL2.setString(1, runDate);
psMSQL2.setString(2, runDate2);
int i = 3;
for (String s : subMSRB) {
psMSQL2.setString(i, s.trim());
i++;
}
ResultSet msSQL = psMSQL2.executeQuery();
logger.debug("SQL executed");
while (msSQL.next()) {
missedMSRB.remove(msSQL.getString(1));
}
getSubList 实现// 更正
public static List<List<String>> getSubList(List<String> inputList, int subListSize) {
int listSize = inputList.size();
int noOfLoops = listSize / subListSize;
int remainingListSize = listSize % subListSize;
List<List<String>> subList = new ArrayList<List<String>>();
for (int i = 0; i < noOfLoops; i++) {
int fromIndex = i * subListSize;
int toIndex = (fromIndex) + subListSize;
subList.add(new ArrayList<String>(inputList.subList(fromIndex, toIndex)));
if ((remainingListSize != 0)
&& (toIndex == (listSize - remainingListSize))) {
subList.add(new ArrayList<String>(inputList.subList(toIndex, listSize)));
}
}
return subList;
}
在 getSubList
中,您使用 inputList.subList
创建了多个列表。在 ArrayList
中实现的 List
中的此方法不会创建新列表。相反,它 returns 是 inputList
的观点,因此得到 inputList
.
的支持
对 inputList
的任何修改都会对子列表产生影响。您已将 missedMSRB
作为 inputList
传递,因此对 missedMSRB
的任何修改都会影响 subList
因此,当您在外部 for
循环中调用 missedMSRB.remove
时,您会为 subList
中的所有列表创建一个 ConcurrentModification
。然后,当您在 subList
中检查其中一个列表的大小时,它会抛出 ConcurrentModificationException
要解决这个问题,您可以创建一个新列表,而不是直接使用 subList
:
的结果
subList.add(new ArrayList<String>(inputList.subList(fromIndex, toIndex)));
missedMSRB 是一个包含 2187 个元素的列表,当尝试 运行 下面的代码片段时
List<List<String>> subList = getSubList(missedMSRB, 1000);
for (List<String> subMSRB : subList) {
StringBuffer sql = new StringBuffer(NamedQueries.msSQL);
sql.append("(");
for (int i1 = 0; i1 < subMSRB.size(); i1++) { //Line 463 Throws Exception
if (i1 < subMSRB.size() - 1) {
sql.append("?,");
} else {
sql.append("? )");
}
} ....
代码失败并出现以下异常任何建议我为什么得到并发修改以及如何摆脱相同的
13 Jan 2015 10:42:58,974 [main] ERROR RunAnalytics: General Error: null
java.util.ConcurrentModificationException
at java.util.ArrayList$SubList.checkForComodification(ArrayList.java:1169)
at java.util.ArrayList$SubList.size(ArrayList.java:998)
at com.abc.Analytics.RunAnalytics.getCountCheck(RunAnalytics.java:463)
at com.abc.Analytics.RunAnalytics.analyticsExecute(RunAnalytics.java:342)
at com.abc.Analytics.RunAnalytics.main(RunAnalytics.java:84)
下方剩余代码
PreparedStatement psMSQL2 = msSQL.prepareStatement(sql.toString());
psMSQL2.setString(1, runDate);
psMSQL2.setString(2, runDate2);
int i = 3;
for (String s : subMSRB) {
psMSQL2.setString(i, s.trim());
i++;
}
ResultSet msSQL = psMSQL2.executeQuery();
logger.debug("SQL executed");
while (msSQL.next()) {
missedMSRB.remove(msSQL.getString(1));
}
getSubList 实现// 更正
public static List<List<String>> getSubList(List<String> inputList, int subListSize) {
int listSize = inputList.size();
int noOfLoops = listSize / subListSize;
int remainingListSize = listSize % subListSize;
List<List<String>> subList = new ArrayList<List<String>>();
for (int i = 0; i < noOfLoops; i++) {
int fromIndex = i * subListSize;
int toIndex = (fromIndex) + subListSize;
subList.add(new ArrayList<String>(inputList.subList(fromIndex, toIndex)));
if ((remainingListSize != 0)
&& (toIndex == (listSize - remainingListSize))) {
subList.add(new ArrayList<String>(inputList.subList(toIndex, listSize)));
}
}
return subList;
}
在 getSubList
中,您使用 inputList.subList
创建了多个列表。在 ArrayList
中实现的 List
中的此方法不会创建新列表。相反,它 returns 是 inputList
的观点,因此得到 inputList
.
对 inputList
的任何修改都会对子列表产生影响。您已将 missedMSRB
作为 inputList
传递,因此对 missedMSRB
的任何修改都会影响 subList
因此,当您在外部 for
循环中调用 missedMSRB.remove
时,您会为 subList
中的所有列表创建一个 ConcurrentModification
。然后,当您在 subList
中检查其中一个列表的大小时,它会抛出 ConcurrentModificationException
要解决这个问题,您可以创建一个新列表,而不是直接使用 subList
:
subList.add(new ArrayList<String>(inputList.subList(fromIndex, toIndex)));