JAVA集合遍历之Set

本文深入探讨了Java集合框架中HashSet, TreeSet及LinkedHashSet的特点与应用。对比了不同遍历方式的性能,分析了它们在存储与检索数据方面的优劣。

HashSet(无序,插入顺序不一定和输出顺序一致,按hash值插入)

(1)超级for

import java.util.HashSet;


public class Set_HashSet {
	public static void main(String[] args) {
		HashSet<String> set=new HashSet<String>();
		set.add("A");
		set.add("B");
		set.add("C");
		for(String str:set){
			System.out.println(str);
		}
	}
}

(2)迭代器

import java.util.HashSet;
import java.util.Iterator;


public class Set_HashSet {
	public static void main(String[] args) {
		HashSet<String> set=new HashSet<String>();
		set.add("A");
		set.add("B");
		set.add("C");
		Iterator<String> iterator=set.iterator();
		while(iterator.hasNext()){
			System.out.println(iterator.next());
		}
	}
}

两者速度比较

 超级for 迭代器
10万10ms9ms
100万49ms50ms
1000万444ms432ms

TreeSet

(1)超级for

import java.util.TreeSet;

public class Set_TreeSet {
	public static void main(String[] args) {
		TreeSet<String> treeSet = new TreeSet<String>();
		treeSet.add("B");
		treeSet.add("A");
		treeSet.add("C");
		for (String str : treeSet) {
			System.out.println(str);
		}
	}
}

(2)迭代器

import java.util.Iterator;
import java.util.TreeSet;

public class Set_TreeSet {
	public static void main(String[] args) {
		TreeSet<String> treeSet = new TreeSet<String>();
		treeSet.add("B");
		treeSet.add("A");
		treeSet.add("C");
		Iterator<String>iterator=treeSet.iterator();
		while (iterator.hasNext()) {
			System.out.println(iterator.next());
		}
	}
}

两者速度比较

 超级for 迭代器
10万10ms21ms
100万43ms89ms
1000万339ms696ms

LinkedHashSet(同样根据hashCode值来决定元素的存储位置,但是它同时使用链表维护元素的次序,所以输出顺序与插入顺序一致)

(1)超级for
import java.util.LinkedHashSet;


public class Set_LinkedHashSet {

	public static void main(String[] args) {
		LinkedHashSet<String>linkedHashSet=new LinkedHashSet<String>();
		linkedHashSet.add("A");
		linkedHashSet.add("B");
		linkedHashSet.add("C");
		for (String str: linkedHashSet) {
			System.out.println(str);
		}
	}
}

(2)迭代器

import java.util.Iterator;
import java.util.LinkedHashSet;


public class Set_LinkedHashSet {

	public static void main(String[] args) {
		LinkedHashSet<String>linkedHashSet=new LinkedHashSet<String>();
		linkedHashSet.add("A");
		linkedHashSet.add("B");
		linkedHashSet.add("C");
		Iterator<String>iterator=linkedHashSet.iterator();
		while (iterator.hasNext()) {
			iterator.next();
		}
	}
}

两者速度比较

 超级for 迭代器
10万5ms7ms
100万22ms28ms
1000万162ms215ms

总结

linkedHashSet相比较于HashSet,其遍历速度比较快,但是由有要保证有序,其插入速度比较慢。

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值