📌  相关文章
📜  Java中的 LinkedBlockingDeque toArray() 方法示例

📅  最后修改于: 2022-05-13 01:54:57.627000             🧑  作者: Mango

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]