Java Stack类中的toArray(T[])方法及其示例
Java中Stack类的 toArray(T[]) 方法用于形成与Stack中相同元素的数组。它以 正确的顺序 返回包含此Stack中所有元素的数组;返回数组的运行时类型与指定数组的类型相同。如果Stack适合指定的数组,则返回其中。否则,将为此目的分配运行时类型与指定数组类型相同的新数组,并分配此Stack的大小。
如果指定的数组有多余的空间(即数组有比Stack更多的元素),则在Stack结尾之后立即设置数组中的元素为null。(仅当调用者知道Stack不包含任何null元素时,才有用于确定Stack的长度。)
语法:
Object[] arr1 = Stack.toArray(arr[])
参数:
该方法接受一个参数 arr[] ,如果它足够大,则是要将Stack元素存储到其中的数组;否则将为此目的分配相同运行时类型的新数组。
返回值:
该方法返回一个包含与Stack类似的元素的数组。
异常:
- 数组存储异常( ArrayStoreException ) :当所提及的数组是不同类型的,并且无法与Stack中提到的元素进行比较时。
- 空指针异常( NullPointerException ) :如果数组为Null,则会抛出此异常。
下面的程序说明了Stack.toArray(arr[])方法的工作原理。
程序1:当数组的大小与Stack相同时
// Java code to illustrate toArray(arr[])
import java.util.*;
public class StackDemo {
public static void main(String args[])
{
// Creating an empty Stack
Stack<String> stack = new Stack<String>();
// Use add() method to add elements into the Stack
stack.add("Welcome");
stack.add("To");
stack.add("Geeks");
stack.add("For");
stack.add("Geeks");
// Displaying the Stack
System.out.println("The Stack: " + stack);
// Creating the array and using toArray()
String[] arr = new String[5];
arr = stack.toArray(arr);
// Displaying arr
System.out.println("The arr[] is:");
for (int j = 0; j < arr.length; j++)
System.out.println(arr[j]);
}
}
The Stack: [Welcome, To, Geeks, For, Geeks]
The arr[] is:
Welcome
To
Geeks
For
Geeks
程序2:当数组的大小小于Stack时
// Java code to illustrate toArray(arr[])
import java.util.*;
public class StackDemo {
public static void main(String args[])
{
// Creating an empty Stack
Stack<String> stack = new Stack<String>();
// Use add() method to add elements into the Stack
stack.add("Welcome");
stack.add("To");
stack.add("Geeks");
stack.add("For");
stack.add("Geeks");
// Displaying the Stack
System.out.println("The Stack: " + stack);
// Creating the array and using toArray()
String[] arr = new String[1];
arr = stack.toArray(arr);
// Displaying arr
System.out.println("Thearr[] is:");
for (int j = 0; j < arr.length; j++)
System.out.println(arr[j]);
}
}
栈:[Welcome, To, Geeks, For, Geeks]
arr[]是:
Welcome
To
Geeks
For
Geeks
程序3:当数组大小超过栈大小时
// Java代码演示toArray(arr[])
import java.util.*;
public class StackDemo {
public static void main(String args[])
{
// 创建一个空栈
Stack<String> stack = new Stack<String>();
// 使用add()方法向栈中添加元素
stack.add("Welcome");
stack.add("To");
stack.add("Geeks");
stack.add("For");
stack.add("Geeks");
// 显示栈
System.out.println("栈:" + stack);
// 创建数组并使用toArray()
String[] arr = new String[10];
arr = stack.toArray(arr);
// 显示arr
System.out.println("arr[]是:");
for (int j = 0; j < arr.length; j++)
System.out.println(arr[j]);
}
}
栈:[Welcome, To, Geeks, For, Geeks]
arr[]是:
Welcome
To
Geeks
For
Geeks
null
null
null
null
null
程序4:演示NullPointerException
// Java代码演示toArray(arr[])
import java.util.*;
public class StackDemo {
public static void main(String args[])
{
// 创建一个空栈
Stack<String> stack = new Stack<String>();
// 使用add()方法向栈中添加元素
stack.add("Welcome");
stack.add("To");
stack.add("Geeks");
stack.add("For");
stack.add("Geeks");
// 显示栈
System.out.println("栈:" + stack);
try {
// 创建数组
String[] arr = null;
// 使用toArray()
// 由于arr为null
// 因此会抛出异常
arr = stack.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);
}
}
}
栈:[Welcome, To, Geeks, For, Geeks]
异常:java.lang.NullPointerException