溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java常范的幾種錯誤

發布時間:2020-06-16 09:48:50 來源:億速云 閱讀:165 作者:Leah 欄目:編程語言

這篇文章將為大家詳細講解有關java常范的幾種錯誤,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

1、空指針錯誤

在java數組的使用中,有時候需要對字符串數組中的元素進行對比。那么當元素不為null時,程序會正常運行;然而,一旦對比的元素為null,那么程序就會出現空指針錯誤。

解決方法:加入保護,當元素不為null時在進行判斷。

public static void main(Sring[] args){
  String [] sums = "adfafA";
  for(int i=0;i<sums.length;i++){
    if(sums[]!=null && sums[i].equals(sr)){
      System.out.println("找到元素"+sums[i]);
      break;
    }
  }
}

2、數據的精度范圍與類型轉換

在Java中有4種基礎類型數據:

整型:  -1 2 3 4 ……

浮點型:float 1.3f ;  double 3.2   3.5d (未標明類型,默認最高精度)

字符型:采用Unicode編碼,2字節

布爾型:true、false

四種基礎類型數據的精度范圍各不相同,逐級提升。

如果在使用數據類型時,不注意精度范圍,就會出現數據溢出,從而發生計算錯誤。

四種基礎類型中,整型,浮點型和字符型數據是可以相互轉化的。

轉換規則如下:

①隱形轉換:精度小的數據值,賦值給精度大的值,可以自動轉換。(低級向高級)

②強制轉換:范圍大的數據值,(高級到低級)

③運算自動提升規則:運算中,自動轉換為精度高的數據類型。

3、三種循環的使用

①for 循環:是一種有限次數的循環,在循環前,規定好循環次數。

for(表達式;表達式;表達式){
        循環體
 }

break語句:執行后,立即跳出循環,不在執行后面的語句,且結束所有循環。

continue 語句:執行后,立即跳出當前單詞循環,重新判斷條件是否繼續循。

②While循環語句:適合未知次數的循環。

while(條件表達式){
  語句
 };

③do-While循環:也是未知次數的循環。單至少要先執行一次do,在判斷。如果while成立,繼續循環,反之,結束循環。

do {
 語句
 }while(條件表達式);

4、多次拷貝字符串

測試所不能發現的一個錯誤是生成不可變(immutable)對象的多份拷貝。不可變對象是不可改變的,因此不需要拷貝它。最常用的不可變對象是String。

如果你必須改變一個String對象的內容,你應該使用StringBuffer。下面的代碼會正常工作:

String s = new String ("Text here");

但是,這段代碼性能差,而且沒有必要這么復雜。你還可以用以下的方式來重寫上面的代碼:

String temp = "Text here";
String s = new String (temp);

但是這段代碼包含額外的String,并非完全必要。更好的代碼為:

String s = "Text here";

5、沒有克隆(clone)返回的對象

封裝(encapsulation)是面向對象編程的重要概念。不幸的是,Java為不小心打破封裝提供了方便——Java允許返回私有數據的引用(reference)。下面的代碼揭示了這一點:

import java.awt.Dimension;
  /***Example class.The x and y values should never*be negative.*/
  public class Example{
  private Dimension d = new Dimension (0, 0);
  public Example (){ }
  /*** Set height and width. Both height and width must be nonnegative * or an exception is thrown.*/
  public synchronized void setValues (int height,int width) throws IllegalArgumentException{
  if (height <0 || width <0)
  throw new IllegalArgumentException();
  d.height = height;
  d.width = width;
  }
  public synchronized Dimension getValues(){
  // Ooops! Breaks encapsulation
  return d;
  }
  }

Example類保證了它所存儲的height和width值永遠非負數,試圖使用setValues()方法來設置負值會觸發異常。不幸的是,由于getValues()返回d的引用,而不是d的拷貝,你可以編寫如下的破壞性代碼:

  Example ex = new Example();
  Dimension d = ex.getValues();
  d.height = -5;
  d.width = -10;

現在,Example對象擁有負值了!如果getValues() 的調用者永遠也不設置返回的Dimension對象的width 和height值,那么僅憑測試是不可能檢測到這類的錯誤。

不幸的是,隨著時間的推移,客戶代碼可能會改變返回的Dimension對象的值,這個時候,追尋錯誤的根源是件枯燥且費時的事情,尤其是在多線程環境中。

更好的方式是讓getValues()返回拷貝:

  public synchronized Dimension getValues(){
  return new Dimension (d.x, d.y);
  }

6、拷貝錯誤的數據

有時候程序員知道必須返回一個拷貝,但是卻不小心拷貝了錯誤的數據。由于僅僅做了部分的數據拷貝工作,下面的代碼與程序員的意圖有偏差:

import java.awt.Dimension;
  /*** Example class. The height and width values should never * be
  negative. */
  public class Example{
  static final public int TOTAL_VALUES = 10;
  private Dimension[] d = new Dimension[TOTAL_VALUES];
  public Example (){ }
  /*** Set height and width. Both height and width must be nonnegative * or an exception will be thrown. */
  public synchronized void setValues (int index, int height, int width) throws IllegalArgumentException{
  if (height <0 || width <0)
  throw new IllegalArgumentException();
  if (d[index] == null)
  d[index] = new Dimension();
  d[index].height = height;
  d[index].width = width;
  }
  public synchronized Dimension[] getValues()
  throws CloneNotSupportedException{
  return (Dimension[])d.clone();
  }
  }

這兒的問題在于getValues()方法僅僅克隆了數組,而沒有克隆數組中包含的Dimension對象,因此,雖然調用者無法改變內部的數組使其元素指向不同的Dimension對象,但是調用者卻可以改變內部的數組元素(也就是Dimension對象)的內容。方法getValues()的更好版本為:

 public synchronized Dimension[] getValues() throws CloneNotSupportedException{
  Dimension[] copy = (Dimension[])d.clone();
  for (int i = 0; i
  // NOTE: Dimension isn’t cloneable.
  if (d != null)
  copy[i] = new Dimension (d[i].height, d[i].width);
  }
  return copy;
  }

在克隆原子類型數據的多維數組的時候,也會犯類似的錯誤。原子類型包括int,float等。簡單的克隆int型的一維數組是正確的,如下所示:

 public void store (int[] data) throws CloneNotSupportedException{
  this.data = (int[])data.clone();
  // OK
  }

拷貝int型的二維數組更復雜些。Java沒有int型的二維數組,因此一個int型的二維數組實際上是一個這樣的一維數組:它的類型為int[]。簡單的克隆int[][]型的數組會犯與上面例子中getValues()方法第一版本同樣的錯誤,因此應該避免這么做。下面的例子演示了在克隆int型二維數組時錯誤的和正確的做法:

public void wrongStore (int[][] data) throws CloneNotSupportedException{
  this.data = (int[][])data.clone(); // Not OK!
  }
  public void rightStore (int[][] data){
  // OK!
  this.data = (int[][])data.clone();
  for (int i = 0; i
  if (data != null)
  this.data[i] = (int[])data[i].clone();
  }
  }

關于java常范的幾種錯誤就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女