Java中的 LinkedBlockingDeque toArray() 方法示例
toArray()
Java.util.concurrent.LinkedBlockingDeque.toArray()方法返回一个数组,该数组以正确的顺序(即从第一个到最后一个)包含双端队列中的所有元素。当创建一个新数组时,返回的数组将是安全的(因此分配了新的内存)。因此调用者可以自由地修改数组。它充当基于数组和基于集合的 API 之间的桥梁。
句法
public Object[] toArray()
参数:不接受任何参数。
返回值:它返回一个包含双端队列中所有元素的数组。
下面的示例说明了 LinkedBlockingDeque.toArray() 方法:
示例 1:
// Java Program Demonstrate toArray() // method of LinkedBlockingDeque import java.util.concurrent.*; import java.util.*; public class GFG { public static void main(String[] args) throws IllegalStateException { // create object of LinkedBlockingDeque LinkedBlockingDeque
LBD = new LinkedBlockingDeque (); // Add numbers to end of LinkedBlockingDeque LBD.add(7855642); LBD.add(35658786); LBD.add(5278367); LBD.add(74381793); System.out.println("LinkedBlockingDeque: " + LBD); Object[] a = LBD.toArray(); System.out.println("Returned Array: " + Arrays.toString(a)); } } 输出:LinkedBlockingDeque: [7855642, 35658786, 5278367, 74381793] Returned Array: [7855642, 35658786, 5278367, 74381793]
toArray(T[])
Java中LinkedBlockingDeque类的toArray(arr[])方法方法用于组成与LinkedBlockingDeque相同元素的数组。它以正确的顺序返回一个包含此 LinkedBlockingDeque 中所有元素的数组;返回数组的运行时类型是指定数组的类型。如果 LinkedBlockingDeque 适合指定的数组,则在其中返回。否则,将使用指定数组的运行时类型和此 LinkedBlockingDeque 的大小分配一个新数组。
如果 LinkedBlockingDeque 适合指定的数组并有剩余空间(即,数组的元素多于 LinkedBlockingDeque),则数组中紧跟 LinkedBlockingDeque 末尾的元素设置为 null。 (仅当调用者知道 LinkedBlockingDeque 不包含任何空元素时,这对于确定 LinkedBlockingDeque 的长度很有用。)句法:
public
T[] toArray(T[] a) 参数:该方法接受一个参数arr[] ,如果它足够大,则该参数是要存储 LinkedBlockingDeque 的元素的数组;否则,将为此目的分配相同运行时类型的新数组。
返回值:该方法返回一个包含类似于 LinkedBlockingDeque 元素的数组。
异常:该方法可能会抛出两种类型的异常:
- ArrayStoreException :当提到的数组属于不同类型并且无法与 LinkedBlockingDeque 中提到的元素进行比较时。
- NullPointerException :如果数组为 Null,则抛出此异常。
下面的程序说明了 LinkedBlockingDeque.toArray(arr[]) 方法的工作。
程序 1:当数组大小为 LinkedBlockingDeque 时
// Java code to illustrate toArray(arr[]) import java.util.concurrent.*; import java.util.*; public class LinkedBlockingDequeDemo { public static void main(String args[]) { // Creating an empty LinkedBlockingDeque LinkedBlockingDeque
LBD = new LinkedBlockingDeque (); // Use add() method to add // elements into the LinkedBlockingDeque LBD.add("Welcome"); LBD.add("To"); LBD.add("Geeks"); LBD.add("For"); LBD.add("Geeks"); // Displaying the LinkedBlockingDeque System.out.println("The LinkedBlockingDeque: " + LBD); // Creating the array and using toArray() String[] arr = new String[5]; arr = LBD.toArray(arr); // Displaying arr System.out.println("Returned Array: " + Arrays.toString(arr)); } } 输出:The LinkedBlockingDeque: [Welcome, To, Geeks, For, Geeks] Returned Array: [Welcome, To, Geeks, For, Geeks]