📜  Java中的 AbstractSet toArray(T[]) 方法与示例

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

Java中的 AbstractSet toArray(T[]) 方法与示例

Java中AbstractSet类toArray(T[])方法方法用于组成与AbstractSet相同元素的数组。它以正确的顺序返回一个包含此 AbstractSet 中所有元素的数组;返回数组的运行时类型是指定数组的类型。如果 AbstractSet 适合指定的数组,则在其中返回。否则,将使用指定数组的运行时类型和此 AbstractSet 的大小分配一个新数组。
如果AbstractSet 适合指定的数组并有剩余空间(即,该数组的元素多于AbstractSet),则数组中紧跟AbstractSet 末尾的元素设置为null。 (仅当调用者知道 AbstractSet 不包含任何空元素时,这对确定 AbstractSet 的长度很有用。)

句法:

public  T[] toArray(T[] a)

参数:该方法接受一个参数arr[] ,如果它足够大,则该参数是要存储 AbstractSet 元素的数组;否则,将为此目的分配相同运行时类型的新数组。

返回值:该方法返回一个包含与 AbstractSet 类似的元素的数组。

异常:该方法可能会抛出两种类型的异常:

  • ArrayStoreException :当提到的数组属于不同类型并且无法与 AbstractSet 中提到的元素进行比较时。
  • NullPointerException :如果数组为 Null,则抛出此异常。

下面的程序说明了 AbstractSet.toArray(arr[]) 方法的工作。

程序 1:当数组大小为 AbstractSet 时

// Java code to illustrate toArray(arr[])
  
import java.util.*;
  
public class AbstractSetDemo {
    public static void main(String args[])
    {
        // Creating an empty AbstractSet
        AbstractSet
            abs_col = new TreeSet();
  
        // Use add() method to add
        // elements into the AbstractSet
        abs_col.add("Welcome");
        abs_col.add("To");
        abs_col.add("Geeks");
        abs_col.add("For");
        abs_col.add("Geeks");
  
        // Displaying the AbstractSet
        System.out.println("The AbstractSet: "
                           + abs_col);
  
        // Creating the array and using toArray()
        String[] arr = new String[5];
        arr = abs_col.toArray(arr);
  
        // Displaying arr
        System.out.println("The arr[] is:");
        for (int j = 0; j < arr.length; j++)
            System.out.println(arr[j]);
    }
}
输出:
The AbstractSet: [For, Geeks, To, Welcome]
The arr[] is:
For
Geeks
To
Welcome
null

程序 2:当数组小于 AbstractSet 的大小时

// Java code to illustrate toArray(arr[])
  
import java.util.*;
  
public class AbstractSetDemo {
    public static void main(String args[])
    {
        // Creating an empty AbstractSet
        AbstractSet
            abs_col = new TreeSet();
  
        // Use add() method to add
        // elements into the AbstractSet
        abs_col.add("Welcome");
        abs_col.add("To");
        abs_col.add("Geeks");
        abs_col.add("For");
        abs_col.add("Geeks");
  
        // Displaying the AbstractSet
        System.out.println("The AbstractSet: "
                           + abs_col);
  
        // Creating the array and using toArray()
        String[] arr = new String[1];
        arr = abs_col.toArray(arr);
  
        // Displaying arr
        System.out.println("The arr[] is:");
        for (int j = 0; j < arr.length; j++)
            System.out.println(arr[j]);
    }
}
输出:
The AbstractSet: [For, Geeks, To, Welcome]
The arr[] is:
For
Geeks
To
Welcome

程序 3:当数组大于 AbstractSet 的大小时

// Java code to illustrate toArray(arr[])
  
import java.util.*;
  
public class AbstractSetDemo {
    public static void main(String args[])
    {
        // Creating an empty AbstractSet
        AbstractSet
            abs_col = new TreeSet();
  
        // Use add() method to add
        // elements into the AbstractSet
        abs_col.add("Welcome");
        abs_col.add("To");
        abs_col.add("Geeks");
        abs_col.add("For");
        abs_col.add("Geeks");
  
        // Displaying the AbstractSet
        System.out.println("The AbstractSet: "
                           + abs_col);
  
        // Creating the array and using toArray()
        String[] arr = new String[10];
        arr = abs_col.toArray(arr);
  
        // Displaying arr
        System.out.println("The arr[] is:");
        for (int j = 0; j < arr.length; j++)
            System.out.println(arr[j]);
    }
}
输出:
The AbstractSet: [For, Geeks, To, Welcome]
The arr[] is:
For
Geeks
To
Welcome
null
null
null
null
null
null

程序4:演示NullPointerException

// Java code to illustrate toArray(arr[])
  
import java.util.*;
  
public class AbstractSetDemo {
    public static void main(String args[])
    {
        // Creating an empty AbstractSet
        AbstractSet
            abs_col = new TreeSet();
  
        // Use add() method to add
        // elements into the AbstractSet
        abs_col.add("Welcome");
        abs_col.add("To");
        abs_col.add("Geeks");
        abs_col.add("For");
        abs_col.add("Geeks");
  
        // Displaying the AbstractSet
        System.out.println("The AbstractSet: "
                           + abs_col);
  
        try {
            // Creating the array
            String[] arr = null;
            // using toArray()
            // Since arr is null
            // Hence exception will be thrown
            arr = abs_col.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 AbstractSet: [For, Geeks, To, Welcome]
Exception: java.lang.NullPointerException