java中List的toArray()方法用法舉例
toArray()介紹
toArray()方法是List接口中提供的方法,用來(lái)實(shí)現(xiàn)List對(duì)象轉(zhuǎn)換為數(shù)組對(duì)象的功能。
toArray()方法有兩種形式,無(wú)參方法和帶泛型的方法,接下來(lái)給出例子。
1.toArray()
// toArray()源碼
public Object[] toArray() {
return Arrays.copyOf(elementData, size);
}
該方法不能指定轉(zhuǎn)換數(shù)組的類型,返回值只能是Object()數(shù)組,所以得到返回值后往往需要做類型轉(zhuǎn)換,將Object[]轉(zhuǎn)換為我們需要的類型。但是,往往在轉(zhuǎn)換這一部會(huì)出問(wèn)題,如下例:
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
Integer[] res = new Integer[list.size()];
res = (Integer[])list.toArray();該代碼能通過(guò)語(yǔ)法檢查,但是在運(yùn)行時(shí)會(huì)報(bào)類型轉(zhuǎn)換錯(cuò)誤,說(shuō)明Object()不能簡(jiǎn)單地轉(zhuǎn)換為其他類型的數(shù)組。
java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to [Ljava.lang.Integer;
2.toArray(T[] a)
// toArray(T[] a)源碼
public <T> T[] toArray(T[] a) {
if (a.length < size)
// Make a new array of a's runtime type, but my contents:
return (T[]) Arrays.copyOf(elementData, size, a.getClass());
System.arraycopy(elementData, 0, a, 0, size);
if (a.length > size)
a[size] = null;
return a;
}
該方法比前一種無(wú)參的方法更靈活,要求用戶提供一個(gè)目標(biāo)對(duì)象的泛型,在數(shù)組轉(zhuǎn)換后,會(huì)返回一個(gè)指定類型的數(shù)組,不存在類型轉(zhuǎn)換錯(cuò)誤。使用舉例:
List<String> list = new ArrayList<>();
list.add("1");
list.add("2");
list.add("3");
String[] res = new String[list.size()];
這樣就可以將List對(duì)象轉(zhuǎn)換為String[]了。
List轉(zhuǎn)換為int[]的三種方法
上邊介紹toArray()時(shí)給出了兩種方法,第二種帶泛型的方法使用范圍更廣。我最近使用了第二個(gè)方法,發(fā)現(xiàn)了一些問(wèn)題。我要實(shí)現(xiàn)的功能如下:
給定 一個(gè)List對(duì)象:List list = new ArrayList<>();將其轉(zhuǎn)換為一個(gè)int[]數(shù)組。
我toArray()帶泛型的方法來(lái)實(shí)現(xiàn),代碼如下:
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
int[] res = new int[list.size()];
res = list.toArray(res);
但是實(shí)際上上面的代碼是錯(cuò)的,因?yàn)閠oArray()的泛型參數(shù)不能是int,只能是其包裝類Integer,所以通過(guò)toArray()不能直接將List對(duì)象轉(zhuǎn)換為一般類型的數(shù)組,具體的轉(zhuǎn)換方法有如下三種:
法一:循環(huán)賦值
將List中的元素一個(gè)個(gè)取出來(lái),賦值到int[]數(shù)組中的對(duì)應(yīng)位置。
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
int[] res = new int[list.size()];
for(int i = 0; i < list.size(); i++){
res[i] = list[i];
}
這個(gè)方法雖然需要遍歷,但是思路簡(jiǎn)單,一般不會(huì)出錯(cuò)。
法二:通過(guò)泛型實(shí)現(xiàn)轉(zhuǎn)換
以最終目標(biāo)數(shù)組為int[]為例,從List轉(zhuǎn)換為int[]數(shù)組,可以借助于Integer[]數(shù)組來(lái)實(shí)現(xiàn),代碼如下:
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
Integer[] res = new Integer[list.size()];
res = list.toArray(res);
這樣可以得到一個(gè)Integer[]數(shù)組,然后再使用循環(huán)賦值將Integer[]數(shù)組轉(zhuǎn)換為int[]數(shù)組即可。
法三:使用流
使用Java1.8中提供的新方法來(lái)實(shí)現(xiàn)。以下是List、Integer[]、int[]三者的相互轉(zhuǎn)換代碼
int[] data = {4, 5, 3, 6, 2, 5, 1};
// int[] 轉(zhuǎn) List<Integer>
List<Integer> list1 = Arrays.stream(data).boxed().collect(Collectors.toList());
// Arrays.stream(arr) 可以替換成IntStream.of(arr)。
// 1.使用Arrays.stream將int[]轉(zhuǎn)換成IntStream。
// 2.使用IntStream中的boxed()裝箱。將IntStream轉(zhuǎn)換成Stream<Integer>。
// 3.使用Stream的collect(),將Stream<T>轉(zhuǎn)換成List<T>,因此正是List<Integer>。
// int[] 轉(zhuǎn) Integer[]
Integer[] integers1 = Arrays.stream(data).boxed().toArray(Integer[]::new);
// 前兩步同上,此時(shí)是Stream<Integer>。
// 然后使用Stream的toArray,傳入IntFunction<A[]> generator。
// 這樣就可以返回Integer數(shù)組。
// 不然默認(rèn)是Object[]。
// List<Integer> 轉(zhuǎn) Integer[]
Integer[] integers2 = list1.toArray(new Integer[0]);
// 調(diào)用toArray。傳入?yún)?shù)T[] a。這種用法是目前推薦的。
// List<String>轉(zhuǎn)String[]也同理。
// List<Integer> 轉(zhuǎn) int[]
int[] arr1 = list1.stream().mapToInt(Integer::valueOf).toArray();
// 想要轉(zhuǎn)換成int[]類型,就得先轉(zhuǎn)成IntStream。
// 這里就通過(guò)mapToInt()把Stream<Integer>調(diào)用Integer::valueOf來(lái)轉(zhuǎn)成IntStream
// 而IntStream中默認(rèn)toArray()轉(zhuǎn)成int[]。
// Integer[] 轉(zhuǎn) int[]
int[] arr2 = Arrays.stream(integers1).mapToInt(Integer::valueOf).toArray();
// 思路同上。先將Integer[]轉(zhuǎn)成Stream<Integer>,再轉(zhuǎn)成IntStream。
// Integer[] 轉(zhuǎn) List<Integer>
List<Integer> list2 = Arrays.asList(integers1);
// 最簡(jiǎn)單的方式。String[]轉(zhuǎn)List<String>也同理。
// 同理 <br> String[] strings1 = {"a", "b", "c"};
// String[] 轉(zhuǎn) List<String>
List<String> list3 = Arrays.asList(strings1);
// List<String> 轉(zhuǎn) String[]
String[] strings2 = list3.toArray(new String[0]);
總結(jié)
到此這篇關(guān)于java中List的toArray()方法用法的文章就介紹到這了,更多相關(guān)java List的toArray()方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Native實(shí)現(xiàn)0.059s啟動(dòng)一個(gè)SpringBoot項(xiàng)目
Spring Native是Spring框架的一個(gè)子項(xiàng)目,旨在提供一種將Spring應(yīng)用程序編譯為本地可執(zhí)行文件的方法,從而提高啟動(dòng)時(shí)間和資源效率,本文主要介紹了Spring Native實(shí)現(xiàn)0.059s啟動(dòng)一個(gè)SpringBoot項(xiàng)目,感興趣的可以了解一下2024-02-02
SpringBoot使用JdbcTemplate操作數(shù)據(jù)庫(kù)
這篇文章主要介紹了SpringBoot使用JdbcTemplate操作數(shù)據(jù)庫(kù),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-07-07
分析Java非阻塞算法Lock-Free的實(shí)現(xiàn)
非阻塞算法一般會(huì)使用CAS來(lái)協(xié)調(diào)線程的操作。雖然非阻塞算法有諸多優(yōu)點(diǎn),但是在實(shí)現(xiàn)上要比基于鎖的算法更加繁瑣和負(fù)責(zé)。本文將會(huì)介紹兩個(gè)是用非阻塞算法實(shí)現(xiàn)的數(shù)據(jù)結(jié)構(gòu)。2021-06-06
Java Web 實(shí)現(xiàn)QQ登錄功能一個(gè)帳號(hào)同一時(shí)間只能一個(gè)人登錄
對(duì)于一個(gè)帳號(hào)在同一時(shí)間只能一個(gè)人登錄,下文給大家介紹的非常詳細(xì),對(duì)java web qq 登錄功能感興趣的朋友一起看看吧2016-11-11
Java人機(jī)猜拳實(shí)現(xiàn)的思路及方法實(shí)例
這篇文章主要給大家介紹了關(guān)于Java人機(jī)猜拳實(shí)現(xiàn)的思路及方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12

