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