Java AbstractSequentialList toArray(T[])方法及示例

Java AbstractSequentialList toArray(T[])方法及示例

Java中 AbstractSequentialList类toArray(arr[]) 方法被用来形成一个与AbstractSequentialList相同元素的数组。它返回一个包含AbstractSequentialList中所有元素的数组 ,并正确的顺序排列; 返回的数组的运行时类型是指定数组的类型。如果AbstractSequentialList适合于指定的数组,它将被返回其中。否则,将分配一个新的数组,其运行时类型为指定的数组和该AbstractSequentialList的大小。如果AbstractSequentialList适合于指定的数组并有剩余空间(即,数组比AbstractSequentialList有更多的元素),那么紧随AbstractSequentialList结尾的数组中的元素被设置为空。(只有当调用者知道AbstractSequentialList不包含任何空元素时,这对确定AbstractSequentialList的长度是有用的。)

语法

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

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

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

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

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

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

程序1: 当数组的大小为AbstractSequentialList时

// Java code to illustrate toArray(arr[])
 
import java.util.*;
 
public class AbstractSequentialListDemo {
    public static void main(String args[])
    {
        // Creating an empty AbstractSequentialList
        AbstractSequentialList<String>
            abs_col = new LinkedList<String>();
 
        // Use add() method to add
        // elements into the AbstractSequentialList
        abs_col.add("Welcome");
        abs_col.add("To");
        abs_col.add("Geeks");
        abs_col.add("For");
        abs_col.add("Geeks");
 
        // Displaying the AbstractSequentialList
        System.out.println("The AbstractSequentialList: "
                           + 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 AbstractSequentialList: [Welcome, To, Geeks, For, Geeks]
The arr[] is:
Welcome
To
Geeks
For
Geeks

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

// Java code to illustrate toArray(arr[])
 
import java.util.*;
 
public class AbstractSequentialListDemo {
    public static void main(String args[])
    {
        // Creating an empty AbstractSequentialList
        AbstractSequentialList<String>
            abs_col = new LinkedList<String>();
 
        // Use add() method to add
        // elements into the AbstractSequentialList
        abs_col.add("Welcome");
        abs_col.add("To");
        abs_col.add("Geeks");
        abs_col.add("For");
        abs_col.add("Geeks");
 
        // Displaying the AbstractSequentialList
        System.out.println("The AbstractSequentialList: "
                           + 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 AbstractSequentialList: [Welcome, To, Geeks, For, Geeks]
The arr[] is:
Welcome
To
Geeks
For
Geeks

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

// Java code to illustrate toArray(arr[])
 
import java.util.*;
 
public class AbstractSequentialListDemo {
    public static void main(String args[])
    {
        // Creating an empty AbstractSequentialList
        AbstractSequentialList<String>
            abs_col = new LinkedList<String>();
 
        // Use add() method to add
        // elements into the AbstractSequentialList
        abs_col.add("Welcome");
        abs_col.add("To");
        abs_col.add("Geeks");
        abs_col.add("For");
        abs_col.add("Geeks");
 
        // Displaying the AbstractSequentialList
        System.out.println("The AbstractSequentialList: "
                           + 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 AbstractSequentialList: [Welcome, To, Geeks, For, Geeks]
The arr[] is:
Welcome
To
Geeks
For
Geeks
null
null
null
null
null

程序4: 演示NullPointerException

// Java code to illustrate toArray(arr[])
 
import java.util.*;
 
public class AbstractSequentialListDemo {
    public static void main(String args[])
    {
        // Creating an empty AbstractSequentialList
        AbstractSequentialList<String>
            abs_col = new LinkedList<String>();
 
        // Use add() method to add
        // elements into the AbstractSequentialList
        abs_col.add("Welcome");
        abs_col.add("To");
        abs_col.add("Geeks");
        abs_col.add("For");
        abs_col.add("Geeks");
 
        // Displaying the AbstractSequentialList
        System.out.println("The AbstractSequentialList: "
                           + 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 AbstractSequentialList: [Welcome, To, Geeks, For, Geeks]
Exception: java.lang.NullPointerException

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程