比较两个ArrayList并从中删除多余的元素。

3

如何比较两个ArrayList?

我有一个sdCoverList数组和一个thumbnailList数组。

02-04 11:05:05.210: I/System.out(4035): HASHED THUMBNAIL[-2122410790, 2043473787, 1914391068, 1785308349, 1656225630, 1527142911, 1398060192, 1268977473, 1139894754, 1010812035, 1242943301, 1113860582, 984777863, 855695144, 726612425, 597529706, 468446987, 339364268, 210281549]
02-04 11:05:05.210: I/System.out(4035): SD COVER LIST[-2122410790, 2043473787, 1914391068, 1785308349, 1268977473, 1656225630, 1527142911, 1139894754, 1398060192, 1010812035, 1242943301, 1113860582, 984777863, 855695144, 726612425, 597529706, 468446987, 339364268, 210281549, 717409028]

在我的SD卡封面列表中,我有一个额外的值想要去除,但首先我需要与缩略图列表数组进行比较。如果两个列表具有相同的元素,则不做任何操作,但如果有一个额外的元素,则从SD卡中删除它。
我的数组列表:
对于sdCoverList:
// CHECK DIRECTORY BEFORE DELETING THEM
            File strPath = new File(Environment.getExternalStorageDirectory() + folderName+"/Covers");
            File yourDir = new File(strPath, "");
            if(yourDir.length()!=0)
            for (File f : yourDir.listFiles()) {
                if (f.isFile())
                {
                    String name = f.getName();
                    sdCoverList.add(name);
                    //System.out.println(sdCoverList);
                }

对于哈希缩略图

for (int a=0;a<=thumbnailList.size()-1;a++)
        {
            String hashed = String.valueOf(thumbnailList.get(a).hashCode());
            Log.d("hashed",hashed);
            hashedThumbnail.add(hashed);
        }

一个好的答案在这里:https://dev59.com/xHNA5IYBdhLWcg3wjOhS#919420 - Ram kiran Pachigolla
如果我已经有一个ArrayList,我该如何使用Collection? - user1234555
@Ramkiran 你好,我已经编辑了上面的代码。 - user1234555
1个回答

9
List<String> sdCoverList = new ArrayList<String>();
sdCoverList.add("-2122410790");
sdCoverList.add("2043473787");
sdCoverList.add("717409028");

List<String> hashedThumbnail = new ArrayList<String>();
hashedThumbnail.add("-2122410790");
hashedThumbnail.add("2043473787");

System.out.println("sdCover List: " + sdCoverList);
System.out.println("hashedThumbnail List: " + hashedThumbnail);


List<String> temp = new ArrayList<String>();
temp.addAll(sdCoverList);
temp.removeAll(hashedThumbnail);

System.out.println("temp List: " + temp);

sdCoverList.removeAll(temp);

System.out.println("sdCover List: " + sdCoverList);

输出结果将会是:
sdCover List: [-2122410790, 2043473787, 717409028]
hashedThumbnail List: [-2122410790, 2043473787]
temp List: [717409028]
sdCover List: [-2122410790, 2043473787]

我有超过50000条记录在数组中,如果我尝试添加所有和删除所有,应用程序会卡住,这种情况下我该怎么办? - Ravi Makvana

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接