Java LinkedBlockingDeque toArray()方法及示例

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]

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程