Java Set –用Java设置
Java Set是元素(或者对象)的集合,其中不包含重复的元素。
Java Set是扩展Collection接口的接口。
与List不同,Java Set不是有序集合,它的元素没有特定的顺序。
Java Set不提供对可以插入元素的位置的控制。
您不能按元素索引访问元素,也不能在列表中搜索元素。
Java集
在本节中,我们将讨论有关Java Set的一些重要点:
Java Set接口是Java Collections Framework的成员。
与"列表"不同,"设置"不允许您添加重复的元素。
Set允许您最多添加一个null元素。
Set接口在Java 8中有一个默认方法:spliterator。
与List和数组不同,Set不支持其元素的索引或者位置。
集支持泛型,我们应该尽可能使用它。
与Set一起使用泛型将避免在运行时出现ClassCastException。我们可以使用Set接口实现来维护唯一元素。
Java Set类图
Java Set接口扩展了Collection接口。
Collection接口扩展了Iterable接口。
一些常用的Set实现类是HashSet,LinkedHashSet,TreeSet,CopyOnWriteArraySet和ConcurrentSkipListSet。
AbstractSet提供Set接口的基本实现,以减少实现Set的工作量。
Java Set方法
在本节中,我们将讨论一些有用的Java Set方法:
int size():获取Set中元素的数量。
boolean isEmpty():检查Set是否为空。
boolean contains(Object o):如果此Set包含指定的元素,则返回true。
Iterator iterator():返回对此集合中的元素进行迭代的迭代器。
元素以不特定的顺序返回。Object [] toArray():返回包含此集合中所有元素的数组。
如果此集合保证其迭代器返回其元素的顺序,则此方法必须以相同的顺序返回元素。boolean add(E e):如果指定的元素尚不存在,则将其添加到此集合中(可选操作)。
boolean remove(Object o):如果指定的元素存在,则从该集合中移除(可选操作)。
boolean removeAll(Collection c):从此集合中删除所有包含在指定集合中的元素(可选操作)。
boolean keepAll(Collection c):仅保留此集合中包含在指定集合中的元素(可选操作)。
void clear():从集合中删除所有元素。
Iterator iterator():返回对此集合中的元素进行迭代的迭代器。
要设置的Java数组
与列表不同,我们无法将Java集直接转换为数组,因为它不是使用数组来实现的。
因此,我们不能使用Arrays类获取设置的数组视图。
我们可以采用另一种方法。
我们可以使用Arrays.asList()方法将数组转换为List,然后使用它创建一个Set。
通过使用这种方法,我们可以通过两种方式隐式设置Java数组。
让我们使用一个简单的示例一个接一个地讨论它们。
方法1在这种方法中,首先我们需要使用给定的数组创建一个List,并使用它来创建Set,如下所示。
import java.util.*;
public class ArrayToSet {
public static void main(String[] args) {
String[] vowels = {"a","e","i","o","u"};
Set<String> vowelsSet = new HashSet>(Arrays.asList(vowels));
System.out.println(vowelsSet);
/**
* Unlike List, Set is NOt backed by array,
* so we can do structural modification without any issues.
*/
vowelsSet.remove("e");
System.out.println(vowelsSet);
vowelsSet.clear();
System.out.println(vowelsSet);
}
}
方法2在这种方法中,我们不使用中间List从数组创建Set。
首先创建一个空的HashSet,然后使用Collections.addAll()将数组元素复制到给定的Set中,如下所示。
import java.util.*;
public class ArrayToSet2 {
public static void main(String[] args) {
String[] vowels = {"a","e","i","o","u"};
Set<String> vowelsSet = new HashSet<>();
Collections.addAll(vowelsSet, vowels);
System.out.println(vowelsSet);
/**
* Unlike List, Set is NOt backed by array,
* so we can do structural modification without any issues.
*/
vowelsSet.remove("e");
System.out.println(vowelsSet);
vowelsSet.clear();
System.out.println(vowelsSet);
}
}
输出:-当我们在两个程序之上运行时,我们将获得如下所示的相同输出。
[a, e, u, i, o] [a, u, i, o] []
Java设置为数组
在本节中,我们将编写一个程序,使用Set.toArray()方法将一组字符串转换为一组字符串,如下所示。
import java.util.*;
public class SetToArray {
public static void main(String[] args) {
Set<String< vowelsSet = new HashSet<>();
//add example
vowelsSet.add("a");
vowelsSet.add("e");
vowelsSet.add("i");
vowelsSet.add("o");
vowelsSet.add("u");
//convert Set to Array
String strArray[] = vowelsSet.toArray(new String[vowelsSet.size()]);
System.out.println(Arrays.toString(strArray));
}
}
输出:-当我们运行上述程序时,将获得以下输出,如下所示。
[a, e, u, i, o]
Java集合排序
众所周知,Set(HashSet)不直接支持排序元素。
它以随机顺序存储和显示其元素。
但是,我们有一些方法可以对元素进行排序,如下所示:
import java.util.*;
public class SetSortingExample {
public static void main(String[] args) {
Set<Integer> intsSet = new HashSet<>();
Random random = new Random();
for (int i = 0; i {return (o2-o1);});
System.out.println("Reverse Sorting: " + intsList2);
//Approach-3
Set<Integer> sortedSet = new TreeSet<>(intsSet);
System.out.println("Sorted Set: " + sortedSet);
}
}
输出:-当我们运行上述程序时,我们将看到以下输出。
[560, 864, 176, 657, 135, 103, 40, 123, 555, 589] Natural Sorting: [40, 103, 123, 135, 176, 555, 560, 589, 657, 864] Before Sorting: [560, 864, 176, 657, 135, 103, 40, 123, 555, 589] Reverse Sorting: [864, 657, 589, 560, 555, 176, 135, 123, 103, 40] Sorted Set: [40, 103, 123, 135, 176, 555, 560, 589, 657, 864]
Java设置通用操作
在Java Set上执行的最常见操作是add,addAll,clear,size等。
下面是一个简单的Java Set示例,显示了常用方法的用法。
import java.util.*;
public class SetCommonOperations
{
public static void main(String args[])
{
Set<String> vowels= new HashSet<>();
//add example
vowels.add("A");
vowels.add("E");
vowels.add("I");
//We cannot insert elements based on index to a Set
System.out.println(vowels);
Set<String> set = new HashSet<>();
set.add("O");
set.add("U");
//appending set elements to letters
vowels.addAll(set);
System.out.println(vowels);
//clear example to empty the set
set.clear();
//size example
System.out.println("letters set size = " + vowels.size());
vowels.clear();
vowels.add("E"); vowels.add("E");vowels.add("I"); vowels.add("O");
System.out.println("Given set contains E element or not? = " + vowels.contains("E"));
}
}
输出:
[A, E, I] [A, E, U, I, O] letters set size = 5 Given set contains E element or not? = true
Java Set迭代器
下面是一个简单的示例,显示了如何遍历Java Set。
import java.util.*;
public class SetIteratorExample
{
public static void main(String[] args)
{
Set<Integer> set = new HashSet<>();
for(int i=0; i<5; i++)
set.add(i);
Iterator iterator = set.iterator();
//simple iteration
while(iterator.hasNext()){
int i = (int) iterator.next();
System.out.print(i + ", ");
}
System.out.println("\n" + set);
//modification of set using iterator
iterator = set.iterator();
while(iterator.hasNext()){
int x = (int) iterator.next();
if(x%2 ==0) iterator.remove();
}
System.out.println(set);
//changing set structure while iterating
iterator = set.iterator();
while(iterator.hasNext()){
//ConcurrentModificationException here
int x = (int) iterator.next();
if(x==1) set.add(10);
}
}
}
Java设置为流
下面是一个简单的示例,显示了如何将Java Set转换为Stream并按照我们的要求执行一些操作。
import java.util.*;
public class SetToStream {
public static void main(String[] args) {
Set<String> vowelsSet = new HashSet<>();
//add example
vowelsSet.add("a");
vowelsSet.add("e");
vowelsSet.add("i");
vowelsSet.add("o");
vowelsSet.add("u");
//convert set to stream
vowelsSet.stream().forEach(System.out::println);
}
}
输出:
a e u i o
Java SE 9集
在Java SE 9版本中,Oracle Corp将向Set接口添加一些有用的实用程序方法。
最好通过一些简单而有用的示例来理解它们。

