欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java開發(fā)人員最常犯的10個(gè)錯(cuò)誤

 更新時(shí)間:2019年07月01日 15:22:57   作者:風(fēng)一樣的碼農(nóng)  
這篇文章主要介紹了Java開發(fā)人員最常犯的10個(gè)錯(cuò)誤,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

這個(gè)列表總結(jié)了10個(gè)Java開發(fā)人員最常犯的錯(cuò)誤。

Array轉(zhuǎn)ArrayList

當(dāng)需要把Array轉(zhuǎn)成ArrayList的時(shí)候,開發(fā)人員經(jīng)常這樣做:

List<String> list = Arrays.asList(arr);

Arrays.asList()會返回一個(gè)ArrayList,但是要特別注意,這個(gè)ArrayList是Arrays類的靜態(tài)內(nèi)部類,并不是java.util.ArrayList類。java.util.Arrays.ArrayList類實(shí)現(xiàn)了set(), get(),contains()方法,但是并沒有實(shí)現(xiàn)增加元素的方法(事實(shí)上是可以調(diào)用add方法,但是沒有具體實(shí)現(xiàn),僅僅拋出UnsupportedOperationException異常),因此它的大小也是固定不變的。為了創(chuàng)建一個(gè)真正的java.util.ArrayList,你應(yīng)該這樣做:

ArrayList<String> arrayList = new ArrayList<String>(Arrays.asList(arr));

ArrayList的構(gòu)造方法可以接收一個(gè)Collection類型,而java.util.Arrays.ArrayList已經(jīng)實(shí)現(xiàn)了該接口。

判斷一個(gè)數(shù)組是否包含某個(gè)值

開發(fā)人員經(jīng)常這樣做:

Set<String> set = new HashSet<String>(Arrays.asList(arr));
return set.contains(targetValue);

以上代碼可以正常工作,但是沒有必要將其轉(zhuǎn)換成set集合,將一個(gè)List轉(zhuǎn)成Set需要額外的時(shí)間,其實(shí)我們可以簡單的使用如下方法即可:

Arrays.asList(arr).contains(targetValue);

或者

for(String s: arr){
 if(s.equals(targetValue))
 return true;
}
return false;

第一種方法可讀性更強(qiáng)。

在循環(huán)內(nèi)部刪除List中的一個(gè)元素

考慮如下代碼,在迭代期間刪除元素:

ArrayList<String> list = new ArrayList<String>(Arrays.asList("a", "b", "c","d"));
for (int i = 0; i < list.size(); i++) {
 list.remove(i);
}
System.out.println(list);

結(jié)果打?。?br />

[b, d]

在上面這個(gè)方法中有一系列的問題,當(dāng)一個(gè)元素被刪除的時(shí)候,list大小減小,然后原先索引指向了其它元素。所以如果你想在循環(huán)里通過索引來刪除多個(gè)元素,將不會正確工作。

你也許知道使用迭代器是在循環(huán)里刪除元素的正確方式,或許你也知道foreach循環(huán)跟迭代器很類似,但事實(shí)情況卻不是這樣,如下代碼:

ArrayList<String> list = new ArrayList<String>(Arrays.asList("a", "b", "c","d"));
for (String s : list) {
 if (s.equals("a"))
 list.remove(s);
}

將拋出ConcurrentModificationException異常。

然而接下來的代碼卻是OK的:

ArrayList<String> list = new ArrayList<String>(Arrays.asList("a", "b", "c","d"));
Iterator<String> iter = list.iterator();
while (iter.hasNext()) {
 String s = iter.next();
 if (s.equals("a")) {
 iter.remove();
 }
}

next()方法需要在remove()方法之前被調(diào)用,在foreach循環(huán)里,編譯器會在刪除元素操作化調(diào)用next方法,這導(dǎo)致了ConcurrentModificationException異常。更多詳細(xì)信息,可以查看ArrayList.iterator()的源碼。

HashTable與HashMap

從算法的角度來講,HashTable是一種數(shù)據(jù)結(jié)構(gòu)名稱。但是在Java中,這種數(shù)據(jù)結(jié)構(gòu)叫做HashMap。HashTable與HashMap的一個(gè)主要的區(qū)別是HashTable是同步的,所以,通常來說,你會使用HashMap,而不是Hashtable。

更多信息:HashMap vs. TreeMap vs. Hashtable vs. LinkedHashMap Top 10 questions about Map

使用集合原始類型(raw type)

在Java中,原始類型(raw type)和無界通配符類型很容易讓人混淆。舉個(gè)Set的例子,Set是原始類型,而Set是無界通配符類型。

請看如下代碼,add方法使用了一個(gè)原始類型的List作為入?yún)ⅲ?/p>

public static void add(List list, Object o){
 list.add(o);
}
public static void main(String[] args){
 List<String> list = new ArrayList<String>();
 add(list, 10);
 String s = list.get(0);
}

運(yùn)行以上代碼將會拋出異常:

Exception in thread "main" java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
at ...

使用原始類型集合非常危險(xiǎn),因?yàn)樗^了泛型類型檢查,是不安全的。另外,Set, Set, 和Set這三個(gè)有很大的不同,具體請看:類型擦除和Raw type vs. Unbounded wildcard。

訪問級別

開發(fā)人員經(jīng)常使用public修飾類字段,雖然這很容易讓別人直接通過引用獲取該字段的值,但這是一個(gè)不好的設(shè)計(jì)。根據(jù)經(jīng)驗(yàn),應(yīng)該盡可能的降低成員屬性的訪問級別。

相關(guān)閱讀:public, default, protected, and private

ArrayList和LinkedList

為什么開發(fā)人員經(jīng)常使用ArrayList和LinkedList,卻不知道他們之間的區(qū)別,因?yàn)樗鼈兛雌饋砗芟?。然而它們之間有著巨大的性能差異。簡單的說,如果有大量的增加刪除操作并且沒有很多的隨機(jī)訪問元素的操作,應(yīng)該首選LinkedList。

可變與不可變

不可變對象有很多優(yōu)點(diǎn),如簡單、安全等。但是對于每個(gè)不同的值都需要一個(gè)單獨(dú)的對象,太多的對象會引起大量垃圾回收,因此在選擇可變與不可變的時(shí)候,需要有一個(gè)平衡。

通常,可變對象用于避免產(chǎn)生大量的中間對象,一個(gè)經(jīng)典的例子是大量字符串的拼接。如果你使用一個(gè)不可變對象,將會馬上產(chǎn)生大量符合垃圾回收標(biāo)準(zhǔn)的對象,這浪費(fèi)了CPU大量的時(shí)間和精力。使用可變對象是正確的解決方案(StringBuilder);

String result="";
for(String s: arr){
 result = result + s;
}

另外,在有些其它情況下也是需要使用可變對象。例如往一個(gè)方法傳入一個(gè)可變對象,然后收集多種結(jié)果,而不需要

寫太多的語法。另一個(gè)例子是排序和過濾:當(dāng)然,你可以寫一個(gè)方法來接收原始的集合,并且返回一個(gè)排好序的集合,但是那樣對于大的集合就太浪費(fèi)了。

Why we need mutable classes?

父類和子類的構(gòu)造方法

之所以出現(xiàn)這個(gè)編譯錯(cuò)誤,是因?yàn)楦割惖哪J(rèn)構(gòu)造方法未定義。在Java中,如果一個(gè)類沒有定義構(gòu)造方法,編譯器會默認(rèn)插入一個(gè)無參數(shù)的構(gòu)造方法;但是如果一個(gè)構(gòu)造方法在父類中已定義,在這種情況,編譯器是不會自動插入一個(gè)默認(rèn)的無參構(gòu)造方法,這正是以上demo的情況;

對于子類來說,不管是無參構(gòu)造方法還是有參構(gòu)造方法,都會默認(rèn)調(diào)用父類的無參構(gòu)造方法;當(dāng)編譯器嘗試在子類中往這兩個(gè)構(gòu)造方法插入super()方法時(shí),因?yàn)楦割悰]有一個(gè)默認(rèn)的無參構(gòu)造方法,所以編譯器報(bào)錯(cuò);

要修復(fù)這個(gè)錯(cuò)誤,很簡單:

1、在父類手動定義一個(gè)無參構(gòu)造方法:

public Super(){
 System.out.println("Super");
}

2、移除父類中自定義的構(gòu)造方法

3、在子類中自己寫上父類構(gòu)造方法的調(diào)用;如super(value);

“”還是構(gòu)造方法

有兩種創(chuàng)建字符串的方式:

//1. use double quotes
String x = "abc";
//2. use constructor
String y = new String("abc");

它們之間有什么區(qū)別呢?

以下代碼提供了一個(gè)快速回答:

String a = "abcd";
String b = "abcd";
System.out.println(a == b); // True
System.out.println(a.equals(b)); // True
String c = new String("abcd");
String d = new String("abcd");
System.out.println(c == d); // False
System.out.println(c.equals(d)); // True

未來工作

這個(gè)列表是我基于大量的github上的開源項(xiàng)目,Stack overflow上的問題,還有一些流行的google搜索的分析。沒有明顯示的評估證明它們是前10,但它們絕對是很常見的。如果您不同意任一部分,請 留下您的評論。如果您能提出其它一些常見的錯(cuò)誤,我將會非常感激。

總結(jié)

以上所述是小編給大家介紹的Java開發(fā)人員最常犯的10個(gè)錯(cuò)誤,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時(shí)回復(fù)大家的!

相關(guān)文章

  • springBoot項(xiàng)目打包idea的多種方法

    springBoot項(xiàng)目打包idea的多種方法

    這篇文章主要介紹了springBoot項(xiàng)目打包idea的多種方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • SpringBoot普通類獲取spring容器中bean的操作

    SpringBoot普通類獲取spring容器中bean的操作

    這篇文章主要介紹了SpringBoot普通類獲取spring容器中bean的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 詳談Enumeration接口和Iterator接口的區(qū)別

    詳談Enumeration接口和Iterator接口的區(qū)別

    下面小編就為大家?guī)硪黄斦凟numeration接口和Iterator接口的區(qū)別。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-08-08
  • Java設(shè)計(jì)模式之適配器模式

    Java設(shè)計(jì)模式之適配器模式

    這篇文章介紹了Java設(shè)計(jì)模式之適配器模式,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • java selenium處理Iframe中的元素示例

    java selenium處理Iframe中的元素示例

    本文主要介紹java selenium處理Iframe中的元素,這里整理了相關(guān)資料并附有示例代碼和實(shí)現(xiàn)方法,有需要的小伙伴可以參考下
    2016-08-08
  • 一文搞懂MyBatis一級緩存和二級緩存

    一文搞懂MyBatis一級緩存和二級緩存

    本文主要介紹了一文搞懂MyBatis一級緩存和二級緩存,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Spring中循環(huán)依賴的解決方法詳析

    Spring中循環(huán)依賴的解決方法詳析

    這篇文章主要給大家介紹了關(guān)于Spring中循環(huán)依賴的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用spring具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • SpringBoot配置SSL同時(shí)支持http和https訪問實(shí)現(xiàn)

    SpringBoot配置SSL同時(shí)支持http和https訪問實(shí)現(xiàn)

    本文主要介紹了SpringBoot配置SSL同時(shí)支持http和https訪問實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Java中的注解與注解處理器

    Java中的注解與注解處理器

    這篇文章主要介紹了Java中的注解與注解處理器,元注解的作用是負(fù)責(zé)注解其他注解, Java5.0定義了4個(gè)標(biāo)準(zhǔn)的meta-annotation(元注解)類型,它們被用來提供對其它注解類型進(jìn)行說明,需要的朋友可以參考下
    2023-11-11
  • Java位運(yùn)算知識點(diǎn)詳解

    Java位運(yùn)算知識點(diǎn)詳解

    這篇文章給大家分享了關(guān)于Java位運(yùn)算的相關(guān)知識點(diǎn)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。
    2018-09-09

最新評論