Java--如何高效向List中存放不重复的数据(附带时间测试)

虽然List是不能存储重复数据的,但是如果你在对接接口,或者有特殊需求时,就需要考虑用List去存放含重复数据的情况。而我们想利用List存储不重复的元素,一般都使用List自带的contains方法对元素进行判断,如果不包含再进行添加,但是这样太耗时了。

if (!list.contains("/home/" + i)) {
	list.add("/home/" + i);
}

其实我们可以利用set集合存储元素的去重特性来进行list的去重存储,如果set能添加,list就进行添加。

if (set.add("/home/" + i)) {
	list.add("/home/" + i);
}

下面我们就来测试几种向List存放不重复数据方法的耗时情况:

public class Test {

	public static List<String> list = new ArrayList<String>();
	public static Set<String> set = new HashSet<>();
	public static Set<String> sortset = new LinkedHashSet<>();

	public static void main(String[] args) {
		// 利用Hashset去重的特性
		long s1 = System.currentTimeMillis();
		for (int i = 0; i < 100000; i++) {
			if (set.add("/home/" + i)) {
				list.add("/home/" + i);
			}
		}
		System.out.println("使用Hashset进行list去重速度:" + (System.currentTimeMillis() - s1));

		// 利用linkedHashSet去重且存放有序的特性
		long s4 = System.currentTimeMillis();
		for (int i = 0; i < 100000; i++) {
			if (sortset.add("/home/" + i)) {
				list.add("/home/" + i);
			}
		}
		System.out.println("使用LinkedHashset进行list去重速度:" + (System.currentTimeMillis() - s4));

		// 利用list自带contains方法做判断
		long s2 = System.currentTimeMillis();
		for (int i = 0; i < 100000; i++) {
			if (!list.contains("/home/" + i)) {
				list.add("/home/" + i);
			}
		}

		System.out.println("使用lists的contain方法去重速度:" + (System.currentTimeMillis() - s2));

		// 先存到HashSet,再将全部元素添加到list中
		long s3 = System.currentTimeMillis();
		for (int i = 0; i < 100000; i++) {
			set.add("/home/" + i);
		}
		list.addAll(set);
		System.out.println("使用set去重,然后添加到list中速度:" + (System.currentTimeMillis() - s3));

	}

}

测试结果如下图:

经过观察我们可以发现,这其中先使用set进行去重,然后再将set所有元素添加到list中是最快的。但是需要注意的是,List的addAll()方法默认是会将要添加集合的元素添加到list的尾部,如果你的这个list中本身包含了其他数据,添加时对顺序有要求的话要谨慎使用。最好是使用第一种方式,使用set是否可以添加作为判断条件,这样在这个过程中还可以附带其他条件。比较灵活。

而使用List的contains方法则耗时最久,与其他方式速度相差几十倍。所以大家以后还是尽量不要使用contains来进行去重的判断了。

喜欢的朋友可以点个赞哦~~

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

stalin_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值