Java中的 Stack toArray(T[]) 方法示例
Java中Stack类的toArray(T[])方法方法用于组成一个与Stack相同元素的数组。它以正确的顺序返回一个包含此 Stack 中所有元素的数组;返回数组的运行时类型是指定数组的类型。如果堆栈适合指定的数组,则在其中返回。否则,使用指定数组的运行时类型和此堆栈的大小分配一个新数组。
如果堆栈适合指定的数组并有剩余空间(即,数组的元素多于堆栈),则数组中紧跟堆栈末尾的元素设置为空。 (仅当调用者知道堆栈不包含任何空元素时,这对确定堆栈的长度很有用。)
句法:
Object[] arr1 = Stack.toArray(arr[])
参数:该方法接受一个参数arr[] ,如果它足够大,则该参数是要存储 Stack 元素的数组;否则,将为此目的分配相同运行时类型的新数组。
返回值:该方法返回一个包含类似于堆栈的元素的数组。
异常:该方法可能会抛出两种类型的异常:
- ArrayStoreException :当提到的数组是不同的类型并且无法与堆栈中提到的元素进行比较时。
- 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 stack = new Stack();
// 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 stack = new Stack();
// 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("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
程序 3:当数组大于 Stack 的大小时
// Java code to illustrate toArray(arr[])
import java.util.*;
public class StackDemo {
public static void main(String args[])
{
// Creating an empty Stack
Stack stack = new Stack();
// 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[10];
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
null
null
null
null
null
程序4:演示NullPointerException
// Java code to illustrate toArray(arr[])
import java.util.*;
public class StackDemo {
public static void main(String args[])
{
// Creating an empty Stack
Stack stack = new Stack();
// 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);
try {
// Creating the array
String[] arr = null;
// using toArray()
// Since arr is null
// Hence exception will be thrown
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]);
}
catch (Exception e) {
System.out.println("Exception: " + e);
}
}
}
输出:
The Stack: [Welcome, To, Geeks, For, Geeks]
Exception: java.lang.NullPointerException