对HashSet遍历的不同方法

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/weixin_44540088/article/details/88354676

类 HashSet简介

此类实现 Set 接口,由哈希表(实际上是一个 HashMap 实例)支持。它不保证 set 的迭代顺序;特别是它不保证该顺序恒久不变。此类允许使用 null 元素。(简而言之,set是无序的,允许重复的)

首先定义一个hashSet对象

HashSet set=new HashSet();
		set.add("123");
		set.add(101);
		set.add('c');
		set.add(2.5);

由于没有指定泛型,所以参数可以为任意值,且从jdk1…5开始有自动装箱拆箱功能,所以原始类型也可以作为参数。

1.第一种方法:利用foreach进行遍历

//通过foreach进行遍历
		for (Object object : set) {
			System.out.println(object);
		}

运行结果如下:

123
c
2.5
101

2.第二种方法:通过迭代器Iterator进行遍历

//通过迭代器Iterator进行遍历
		
		Iterator it=set.iterator();
		while(it.hasNext()) {
			Object o=it.next();
			System.out.println(o);
		}

运行结果如下:

123
c
2.5
101

完整代码段如下:

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

public class HashSetTest {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		HashSet set=new HashSet();
		set.add("123");
		set.add(101);
		set.add('c');
		set.add(2.5);
		
		//通过迭代器Iterator进行遍历
		
		Iterator it=set.iterator();
		while(it.hasNext()) {
			Object o=it.next();
			System.out.println(o);
		}
		System.out.println("=========");
		//通过foreach进行遍历
		for (Object object : set) {
			System.out.println(object);
		}
		
	}

}

运行结果:

123
c
2.5
101
=========
123
c
2.5
101

欢迎大家批评指正,共同进步*(第一次写博客,如有错误请见谅)*

猜你喜欢

转载自blog.csdn.net/weixin_44540088/article/details/88354676