Java TreeSet toArray(T[])方法及实例
Java中TreeSet类的 toArray(T[]) 方法是用来形成一个与TreeSet相同元素的数组。它返回一个包含TreeSet中所有元素的数组 ,顺序正确; 返回的数组的运行时类型是指定数组的类型。如果TreeSet适合指定的数组,它将被返回。否则,将分配一个新的数组,其运行时类型为指定的数组和TreeSet的大小。
如果TreeSet适合在指定的数组中,并有剩余空间(即,数组的元素比TreeSet多),紧随TreeSet结束的数组中的元素被设置为空。(只有当调用者知道TreeSet不包含任何空元素时,这对确定TreeSet的长度才是有用的。)
语法
public <T> T[] toArray(T[] a)
参数: 该方法接受一个参数arr[]
,如果该数组足够大的话,它是存储TreeSet元素的数组;否则,将为此目的分配一个相同运行时类型的新数组。
返回值: 该方法返回一个包含类似于TreeSet元素的数组。
异常: 该方法可能抛出两种类型的异常。
- ArrayStoreException : 当提到的数组是不同的类型并且不能与TreeSet中提到的元素进行比较。
- NullPointerException : 如果数组是空的,就会抛出这个异常。
下面的程序说明了TreeSet.toArray(arr[])方法的工作。
程序1:当数组的大小与TreeSet相同时
// Java code to illustrate toArray(arr[])
import java.util.*;
public class TreeSetDemo {
public static void main(String args[])
{
// Creating an empty TreeSet
TreeSet<String>
set = new TreeSet<String>();
// Use add() method to add
// elements into the TreeSet
set.add("Welcome");
set.add("To");
set.add("Geeks");
set.add("For");
set.add("Geeks");
// Displaying the TreeSet
System.out.println("The TreeSet: "
+ set);
// Creating the array and using toArray()
String[] arr = new String[5];
arr = set.toArray(arr);
// Displaying 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 code to illustrate toArray(arr[])
import java.util.*;
public class TreeSetDemo {
public static void main(String args[])
{
// Creating an empty TreeSet
TreeSet<String>
set = new TreeSet<String>();
// Use add() method to add
// elements into the TreeSet
set.add("Welcome");
set.add("To");
set.add("Geeks");
set.add("For");
set.add("Geeks");
// Displaying the TreeSet
System.out.println("The TreeSet: "
+ set);
// Creating the array and using toArray()
String[] arr = new String[1];
arr = set.toArray(arr);
// Displaying 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
程序3:当数组大于TreeSet的大小时
// Java code to illustrate toArray(arr[])
import java.util.*;
public class TreeSetDemo {
public static void main(String args[])
{
// Creating an empty TreeSet
TreeSet<String>
set = new TreeSet<String>();
// Use add() method to add
// elements into the TreeSet
set.add("Welcome");
set.add("To");
set.add("Geeks");
set.add("For");
set.add("Geeks");
// Displaying the TreeSet
System.out.println("The TreeSet: "
+ set);
// Creating the array and using toArray()
String[] arr = new String[10];
arr = set.toArray(arr);
// Displaying 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
null
null
null
null
null
程序4:演示NullPointerException
// Java code to illustrate toArray(arr[])
import java.util.*;
public class TreeSetDemo {
public static void main(String args[])
{
// Creating an empty TreeSet
TreeSet<String>
set = new TreeSet<String>();
// Use add() method to add
// elements into the TreeSet
set.add("Welcome");
set.add("To");
set.add("Geeks");
set.add("For");
set.add("Geeks");
// Displaying the TreeSet
System.out.println("The TreeSet: "
+ set);
try {
// Creating the array
String[] arr = null;
// using toArray()
// Since arr is null
// Hence exception will be thrown
arr = set.toArray(arr);
// Displaying arr
System.out.println("The arr[] is:");
for (int j = 0; j < arr.length; j++)
System.out.println(arr[j]);
}
catch (Exception e) {
System.out.println("Exception: " + e);
}
}
}
输出:
The TreeSet: [For, Geeks, To, Welcome]
Exception: java.lang.NullPointerException