Java LinkedBlockingDeque toArray()方法及示例
toArray()
Java.util.concurrent.LinkedBlockingDeque.toArray()方法返回一个包含deque中所有元素的数组,并以适当的顺序,即从第一到最后。返回的数组将是安全的,因为一个新的数组被创建(因此新的内存被分配)。因此,调用者可以自由地修改数组。它是基于数组和基于集合的API之间的桥梁。
语法
public Object[] toArray()
参数: 它不接受任何参数。
返回值: 它返回一个包含deque中所有元素的数组。
下面的例子说明了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<Integer> LBD
= new LinkedBlockingDeque<Integer>();
// 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结束的数组中的元素被设置为空。(只有当调用者知道LinkedBlockingDeque不包含任何空元素时,这对于确定LinkedBlockingDeque的长度才是有用的)。
语法:
public <T> T[] toArray(T[] a)
参数:该方法接受一个参数arr[],如果它足够大的话,就是将LinkedBlockingDeque的元素存储到该数组中;否则,将为此目的分配一个相同运行时类型的新数组。
返回值:该方法返回一个包含类似于LinkedBlockingDeque的元素的数组。
异常:该方法可能抛出两种类型的异常。
- ArrayStoreException : 当提到的数组是不同的类型并且不能与LinkedBlockingDeque中提到的元素进行比较。
- NullPointerException : 如果数组是空的,就会抛出这个异常。
下面的程序说明了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<String> LBD
= new LinkedBlockingDeque<String>();
// 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]
极客教程