Java中TreeSet toArray(T[])方法示例
Java中TreeSet类中的 toArray(T[]) 方法用于形成一个与TreeSet相同元素的数组。它返回一个包含此TreeSet中所有元素的数组, 按正确的顺序 。返回的数组的运行时类型是指定数组的类型。如果TreeSet适合于指定的数组,则将其返回。否则,将使用指定数组的运行时类型分配新数组,并使其大小等于该TreeSet的大小。
如果指定的数组可以容纳TreeSet(即数组具有比TreeSet更多的元素),则紧跟在TreeSet结尾的数组元素将设置为null。(仅在调用者知道TreeSet不包含任何null元素时,此选项对于确定TreeSet的长度很有用。)
语法:
public <T> T[] toArray(T[] a)
参数: 该方法接受一个参数arr[],这是一个数组,如果它足够大,则TreeSet的元素将存储在其中;否则将为此目的分配一个新的相同运行时类型的数组。
返回值: 该方法返回包含与TreeSet类似的元素的数组。
异常: 该方法可能抛出两种类型的异常:
- ArrayStoreException:当所述数组与TreeSet中提到的元素的类型不同且无法进行比较时。
- NullPointerException:如果数组为Null,则会抛出此异常。
以下程序说明了TreeSet.toArray(arr[])方法的工作原理。
程序1:当数组大小与TreeSet相同时
// Java代码示例:toArray(arr[])
import java.util.*;
public class TreeSetDemo {
public static void main(String args[])
{
// 创建空的TreeSet
TreeSet<String>
set = new TreeSet<String>();
// 使用add()方法将元素添加到TreeSet中
set.add("Welcome");
set.add("To");
set.add("Geeks");
set.add("For");
set.add("Geeks");
// 显示TreeSet
System.out.println("The TreeSet: "
+ set);
// 创建数组,并使用toArray()
String[] arr = new String[5];
arr = set.toArray(arr);
// 显示arr
System.out.println("The arr[] is:");
for (int j = 0; j < arr.length; j++)
System.out.println(arr[j]);
}
}
The TreeSet: [For, Geeks, To, Welcome]
The arr[] is:
For
Geeks
To
Welcome
null
程序2:当数组大小小于TreeSet时
// Java代码展示了toArray(arr[])方法的用法
import java.util.*;
public class TreeSetDemo {
public static void main(String args[])
{
// 创建一个空的TreeSet集合
TreeSet<String>
set = new TreeSet<String>();
// 使用add()方法向TreeSet中添加元素
set.add("Welcome");
set.add("To");
set.add("Geeks");
set.add("For");
set.add("Geeks");
// 输出TreeSet集合
System.out.println("TreeSet: "
+ set);
// 创建一个数组并使用toArray()
String[] arr = new String[1];
arr = set.toArray(arr);
// 输出数组
System.out.println("arr[]:");
for (int j = 0; j < arr.length; j++)
System.out.println(arr[j]);
}
}
输出结果:
TreeSet: [For, Geeks, To, Welcome]
arr[]:
For
Geeks
To
Welcome
程序3:当数组的大小大于TreeSet集合中的元素数量
// Java代码展示了toArray(arr[])方法的用法
import java.util.*;
public class TreeSetDemo {
public static void main(String args[])
{
// 创建一个空的TreeSet集合
TreeSet<String>
set = new TreeSet<String>();
// 使用add()方法向TreeSet中添加元素
set.add("Welcome");
set.add("To");
set.add("Geeks");
set.add("For");
set.add("Geeks");
// 输出TreeSet集合
System.out.println("TreeSet: "
+ set);
// 创建一个大小为10的数组并使用toArray()
String[] arr = new String[10];
arr = set.toArray(arr);
// 输出数组
System.out.println("arr[]:");
for (int j = 0; j < arr.length; j++)
System.out.println(arr[j]);
}
}
输出结果:
TreeSet: [For, Geeks, To, Welcome]
arr[]:
For
Geeks
To
Welcome
null
null
null
null
null
null
程序4:演示NullPointerException
// Java代码展示了toArray(arr[])方法的用法
import java.util.*;
public class TreeSetDemo {
public static void main(String args[])
{
// 创建一个空的TreeSet集合
TreeSet<String>
set = new TreeSet<String>();
// 使用add()方法向TreeSet中添加元素
set.add("Welcome");
set.add("To");
set.add("Geeks");
set.add("For");
set.add("Geeks");
// 输出TreeSet集合
System.out.println("TreeSet: "
+ set);
try {
// 创建一个空数组
String[] arr = null;
// 使用toArray()
// 因为arr为空,所以抛出异常
arr = set.toArray(arr);
// 输出数组
System.out.println("arr[]:");
for (int j = 0; j < arr.length; j++)
System.out.println(arr[j]);
}
catch (Exception e) {
System.out.println("Exception: " + e);
}
}
}
输出结果:
TreeSet: [For, Geeks, To, Welcome]
Exception: java.lang.NullPointerException
极客教程