系统里面的一个异常:
java.util.ConcurrentModificationException: 2100007002811 has already been modified. This version : Thu Oct 10 13:55:41 HKT 2013 DB version : Thu Dec 19 14:38:01 HKT 2013
at com.gsol.enigma.store.db.DBDOStore.update(DBDOStore.java:309)
at com.gsol.enigma.business.manager.BaseManager.update(BaseManager.java:234)
at com.gsol.enigma.business.persist.SimpleUnitOfWork.saveAllChanges(SimpleUnitOfWork.java:291)
at com.gsol.enigma.business.persist.SimpleUnitOfWork.commit(SimpleUnitOfWork.java:192)
at tests.PSCeTest.testUnpostAllOfflineCertificate4(PSCeTest.java:1928)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at junit.framework.TestCase.runTest(TestCase.java:154)
at junit.framework.TestCase.runBare(TestCase.java:127)
at junit.framework.TestResult$1.protect(TestResult.java:106)
at junit.framework.TestResult.runProtected(TestResult.java:124)
at junit.framework.TestResult.run(TestResult.java:109)
at junit.framework.TestCase.run(TestCase.java:118)
at junit.framework.TestSuite.runTest(TestSuite.java:208)
at junit.framework.TestSuite.run(TestSuite.java:203)
at junit.textui.TestRunner.doRun(TestRunner.java:116)
at junit.textui.TestRunner.doRun(TestRunner.java:109)
at junit.textui.TestRunner.run(TestRunner.java:72)
at tests.PSCeTest.main(PSCeTest.java:120)
问题原因:list在遍历的时候同时又有删除操作。
解决办法:先将要删除的元素用另一个list装起来,等遍历结束再remove掉。
public void test() {
List<String> originalList = new ArrayList<String>();
List<String> delList = new ArrayList<String>(); // 用来装需要删除的元素
for (String str : originalList)
if ("?".equals(str)) {
delList.add(str);
}
originalList.removeAll(delList);// 遍历完成后执行删除
}