这主要是一道关于性能的问题。我有一个所有现有用户的主列表,存在于一个字符串数组 AllUids 中。我也有一个所有过期用户的列表,存在于一个字符串数组 EndUids 中。
我在 Java 中工作,我的目标是从主列表 AllUids 中删除任何存在于过期用户数组中的用户。我知道 PHP 有一个叫做 array_diff 的函数。
我想知道 Java 是否有任何可以比较两个数组并删除在两个数组中都相似的元素的方法。我的目标是性能,这就是为什么我问是否有内置函数。我不想添加任何特殊的包。
我考虑编写一个递归函数,但它似乎效率很低。这两个列表中都有成千上万的用户。为了存在于过期用户列表中,您必须存在于 AllUids 列表中,除非被删除。
示例:
我在 Java 中工作,我的目标是从主列表 AllUids 中删除任何存在于过期用户数组中的用户。我知道 PHP 有一个叫做 array_diff 的函数。
我想知道 Java 是否有任何可以比较两个数组并删除在两个数组中都相似的元素的方法。我的目标是性能,这就是为什么我问是否有内置函数。我不想添加任何特殊的包。
我考虑编写一个递归函数,但它似乎效率很低。这两个列表中都有成千上万的用户。为了存在于过期用户列表中,您必须存在于 AllUids 列表中,除非被删除。
示例:
String[] AllUids = {"Joe", "Tom", "Dan", "Bill", "Hector", "Ron"};
String[] EndUids = {"Dan", "Hector", "Ron"};
我所寻找的功能:
String[] ActiveUids = AllUids.RemoveSimilar(EndUids);
ActiveUids 会长成这样:
{"Joe", "Tom", "Bill"}
谢谢大家, 显然我能写出循环等代码,但我对其效率并不自信。这是每天在生产机器上运行的东西。