Java TreeSet toArray(T[])方法及实例

Java TreeSet toArray(T[])方法及实例

Java中TreeSet类的 toArray(T[]) 方法是用来形成一个与TreeSet相同元素的数组。它返回一个包含TreeSet中所有元素的数组 ,顺序正确; 返回的数组的运行时类型是指定数组的类型。如果TreeSet适合指定的数组,它将被返回。否则,将分配一个新的数组,其运行时类型为指定的数组和TreeSet的大小。

如果TreeSet适合在指定的数组中,并有剩余空间(即,数组的元素比TreeSet多),紧随TreeSet结束的数组中的元素被设置为空。(只有当调用者知道TreeSet不包含任何空元素时,这对确定TreeSet的长度才是有用的。)

语法

public <T> T[] toArray(T[] a)

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

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

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

  • ArrayStoreException : 当提到的数组是不同的类型并且不能与TreeSet中提到的元素进行比较。
  • NullPointerException : 如果数组是空的,就会抛出这个异常。

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

程序1:当数组的大小与TreeSet相同时

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

输出:

The TreeSet: [For, Geeks, To, Welcome]
The arr[] is:
For
Geeks
To
Welcome
null

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

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

输出:

The TreeSet: [For, Geeks, To, Welcome]
The arr[] is:
For
Geeks
To
Welcome

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

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

输出:

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

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程