Java iterator(迭达器),HashSet集合

发布时间:2020-11-14编辑:dyy阅读(325)

java Iterator(迭代器)不是一个集合,它是一种用于访问集合的方法,可用于迭代 ArrayList 和 HashSet 等集合 是 Java 迭代器最简单的实现

迭代器 it 的两个基本操作是 next 、hasNext 和 remove。

调用 it.next() 会返回迭代器的下一个元素,并且更新迭代器的状态。

调用 it.hasNext() 用于检测集合中是否还有元素。

调用 it.remove() 将迭代器返回的元素删除。

Iterator 类位于 java.util 包中,使用前需要引入它

集合想获取一个迭代器可以使用 iterator() 方法:

// 引入 ArrayList 和 Iterator 类
import java.util.ArrayList;
import java.util.Iterator;
public class RunoobTest {
    public static void main(String[] args) {
           // 创建集合
        ArrayList<String> sites = new ArrayList<String>();
        sites.add("Google");
        sites.add("Runoob");
        sites.add("Taobao");
        sites.add("Zhihu");
        // 获取迭代器
        Iterator<String> it = sites.iterator();
             // 输出集合中的第一个元素
        System.out.println(it.next());
    }
}


调用 it.remove() 删除集合中的元素:

// 引入 ArrayList 和 Iterator 类

import java.util.ArrayList;
import java.util.Iterator;
public class RunoobTest {
    public static void main(String[] args) {
        ArrayList<Integer> numbers = new ArrayList<Integer>();
        numbers.add(12);
        numbers.add(8);
        numbers.add(2);
        numbers.add(23);
        Iterator<Integer> it = numbers.iterator();
        while(it.hasNext()) {      //获取集合中所有的元素     
            Integer i = it.next();   
            if(< 10) {  
                it.remove();  //删除小于10的元素
            }
        }
        System.out.println(numbers);
    }
}                                               结果为:12,23

Java HashSet

HashSet 实现了 Set 接口, 基于 HashMap 来实现的,是一个不允许有重复元素的集合,HashSet 允许有 null 值,HashSet 是无序的,不会记录插入的顺序

HashSet 类位于 java.util 包中,使用前需要引入

添加元素可以使用 add() 方法:

// 引入 HashSet 类 

import java.util.HashSet;
public class RunoobTest {
    public static void main(String[] args) {
    HashSet<String> sites = new HashSet<String>();
        sites.add("Google");
        sites.add("Runoob");
        sites.add("Taobao");
        sites.add("Zhihu");
        sites.add("Runoob");  //重复的元素不会被添加
        System.out.println(sites);
    }

}                                结果为:Google,Runoob,Taobao,Zhihu

在上面的实例中,Runoob 被添加了两次,它在集合中也只会出现一次,因为集合中的每个元素都必须是唯一的

使用 contains() 方法来判断元素是否存在于集合当中: System.out.println(sites.contains("Taobao"));

结果为:true

使用 remove() 方法来删除集合中的元素:sites.remove("Taobao"); 

使用 clear 方法删除集合中所有元素:sites.clear();  

计算 HashSet 中的元素数量可以使用 size() 方法: System.out.println(sites.size());  

迭代 HashSet

使用 for-each 来迭代 HashSet 中的元素

// 引入 HashSet 类 

import java.util.HashSet;
public class RunoobTest {
    public static void main(String[] args) {
    HashSet<String> sites = new HashSet<String>();
        sites.add("Google");
        sites.add("Runoob");
        sites.add("Taobao");
        sites.add("Zhihu");
        sites.add("Runoob");    //重复的元素不会被添加
        for (String i : sites) {
            System.out.println(i);
        }
    }
}

标签

评论