1.ArrayList與LinkedList
當(dāng)開發(fā)人員不知道之間的區(qū)別ArrayList和LinkedList他們經(jīng)常使用ArrayList,因?yàn)樗雌饋砗苁煜ぁ5牵鼈冎g存在巨大的性能差異。LinkedList如果存在大量的添加/刪除操作并且沒有大量的隨機(jī)訪問操作,則應(yīng)該首選。
2.可變與不可變
不可變對(duì)象具有諸如簡單性,安全性等諸多優(yōu)點(diǎn)。但是,它需要為每個(gè)不同的值分別創(chuàng)建一個(gè)對(duì)象,并且過多的對(duì)象可能會(huì)導(dǎo)致垃圾收集的高成本。在可變和不可變之間進(jìn)行選擇時(shí)應(yīng)該有一個(gè)平衡。
通常,可變對(duì)象用于避免產(chǎn)生太多中間對(duì)象。一個(gè)典型的例子是連接大量的字符串。如果你使用一個(gè)不可變的字符串,你會(huì)產(chǎn)生很多對(duì)象,這些對(duì)象可以立即進(jìn)行垃圾回收。這浪費(fèi)了時(shí)間和精力在CPU上,使用可變對(duì)象的正確解決方案(例如StringBuilder)。
3.Super和Sub的構(gòu)造函數(shù)
在Java中,如果一個(gè)類沒有定義構(gòu)造函數(shù),編譯器默認(rèn)會(huì)為該類插入一個(gè)默認(rèn)的無參構(gòu)造函數(shù)。如果在Super類中定義了一個(gè)構(gòu)造函數(shù),在這種情況下,Super(String s),編譯器不會(huì)插入默認(rèn)的無參數(shù)構(gòu)造函數(shù)。這是上面超級(jí)類的情況。
Sub類的構(gòu)造函數(shù)(帶有-argument或no-argument)將調(diào)用無參數(shù)的Super構(gòu)造函數(shù)。由于編譯器試圖向Sub類中的2個(gè)構(gòu)造函數(shù)中插入super,但Super的默認(rèn)構(gòu)造函數(shù)未定義,因此編譯器會(huì)報(bào)告錯(cuò)誤消息。
要解決這個(gè)問題,只需要1)添加一個(gè)Super構(gòu)造函數(shù)給Super類
小編是一個(gè)有著5年工作經(jīng)驗(yàn)的java程序員,對(duì)于java,自己有做資料的整合,一個(gè)完整學(xué)習(xí)java的路線,學(xué)習(xí)資料和工具,相信這里有很多學(xué)習(xí)java的小伙伴,我創(chuàng)立了一個(gè)2000人學(xué)習(xí)扣群,479121291。每晚都有java的直播課程。無論是初級(jí)還是進(jìn)階的小伙伴小編我都?xì)g迎!
4.使用原始類型的集合
在Java中,原始類型和無界通配符類型很容易混合在一起。以Set為例,Set是原始類型,Set而是無界通配符類型。
考慮使用原始類型List作為參數(shù)的以下代碼:
這段代碼會(huì)拋出一個(gè)異常,使用原始類型集合是危險(xiǎn)的,因?yàn)樵碱愋图咸^了泛型類型檢查并且不安全。
5.檢查數(shù)組是否包含值
開發(fā)人員經(jīng)常這樣做:
代碼有效,但不需要先將列表轉(zhuǎn)換為首先設(shè)置。將列表轉(zhuǎn)換為集合需要額外的時(shí)間。它可以像下面這樣簡單:Arrays.asList(arr).contains(targetValue);
要么:
6.從循環(huán)內(nèi)的列表中刪除元素
下面的代碼在迭代過程中刪除元素:
它會(huì)拋出ConcurrentModificationException。
相反,以下是確定的:
.next必須在之前被調(diào)用.remove。在foreach循環(huán)中,編譯器會(huì).next在刪除元素的操作之后調(diào)用該函數(shù),從而導(dǎo)致該操作ConcurrentModificationException。你可能想看看ArrayList.iterator的源代碼。
好啦今天的學(xué)習(xí)文章就到這里了喜歡關(guān)注一下吧。