项目遇到了张表50万数据,需要取出数据,做同步数据操作,进行全量比较。
后来试了几种方法,终于找到了较快的方法。多线程根本提高不了速度。因为是做同一件事情。读取的CPU是同一个......
过滤后取得zhihua 集合里面没有vip集合的部分,其实就是差异。
JSONARRAY zhihua =NEW JSONARRAY ();
JSONARRAY vip =NEW JSONARRAY ();
1. long start1 = System.currentTimeMillis();
System.out.println("开始任务..");
for (Object object : vip) {
JSONObject djobject=(JSONObject)object;
zhihua.remove(djobject);
}
System.out.println("zhihua1.size()"+zhihua.size());
long end1 = System.currentTimeMillis();
System.out.println("耗时:"+(end1 - start1) / 1000 + " 秒");
2. long start2 = System.currentTimeMillis();
System.out.println("开始任务..");
zhihua.removeAll(vip);
System.out.println("zhihua2.size()"+zhihua.size());
long end2 = System.currentTimeMillis();
System.out.println("耗时:"+(end2 - start2) / 1000 + " 秒");
测试发现第一种方法貌似更快点。
还有比较集合中的相同方法,可以用JSONARRAY .contains(object)方法。