国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

JAVA規則 中級篇

2019-11-18 13:18:22
字體:
來源:轉載
供稿:網友

  本文介紹的java規則的說明分為3個主要級別,中級是平時開發用的比較多的級別,在今后將陸續寫出其他的規則。遵守了這些規則可以提高程序的效率、使代碼又更好的可讀性等。
  (1) 在finally方法里關掉input或者output 資源
  再方法體里面定義了input或者output流的話,需要在finally里面把它關掉。
  以下這幾種調用不需要遵守這條規則,因為colse()方法不起作用:)
  java.io.StringWriter java.io.ByteArrayOutputStream java.io.ByteArrayInputStream
  假如再方法返回的時候沒有調用close()方法來釋放input()和output()的資源的話,會導致一個系統資源泄漏。而且在任何情況下都要確定在返回全調用了close() 方法,包括出現異常的時候。所以需要在finally方法里面加入這個方法。這樣就保證了在任何情況下都會關閉資源。
  錯誤示例:
  public class CIO {
  public void method (java.io.File f) {
  java.io.FileInputStream fis = null;
  try {
  fis = new java.io.FileInputStream (f);
  fis.read ();
  fis.close ();
  } catch (java.io.FileNotFoundException e1) {
  System.out.  } catch (java.io.IOException e2) {
  System.out.println("I/O Exception");
  }
  // 假如出現異常,這里就不能保證關閉資源。
  }
  }
  修正后的代碼:
  public class CIOFixed {
  public void method (java.io.File f) {
  java.io.FileInputStream fis = null;
  try {
  fis = new java.io.FileInputStream (f);
  fis.read ();
  } catch (java.io.FileNotFoundException e1) {
  System.out.println("File not found");
  } catch (java.io.IOException e2) {
  System.out.println("I/O Exception");
  } finally {
  if (fis != null) {
  try {
  fis.close ();
  } catch (java.io.IOException e) {
  System.out.println("I/O Exception");
  }
  }
  }
  }
  }
  
  (2) else的注重問題.
  一般總認為假如if語句只有一句的話,那么{}就是可要可不要的了。可是假如if有else嵌套的話,就不一樣了,{}是必需的
  錯誤示例:
  if (i < 5)
  if (i < 2)
  i++;
  else
  i--;
  修改后:
  if (i < 5) {
  if (i < 2)
  i++;
  }
  else {
  i--;
  }
  
  (3) 不要再catch()塊里什么代碼也不放
  在catch()塊里面放入一些錯誤處理代碼是一個好的習慣。但是假如catch()里面有有關javadoc 的代碼,那也是可以的。
  錯誤示例:
  try {
  System.in.read ();
  } catch (java.io.IOException e) {
  // 錯誤
  }
  
  正確:
  try {
  System.in.read ();
  } catch (java.io.IOException e) {
  System.out.println("Descr
iptive error");
  }
  參考:Joshua Bloch: "Effective Java - Programming Language Guide".
  Addison-Wesley, 2001, pp. 187
  
  (4) 不要在if條件里面附值
  假如這樣做的話,系統會報告錯誤。在java的很多條件聲明里面用附值是很不明智的,而且系統也會報告錯誤。很輕易引起異常。遵守這條規者能夠使維護簡單,避免不一致。
  錯誤示例:
  if (b = true)
  正確的:
  if (b == true)
  參考:Section 10.4 of http://java.sun.com/docs/codeconv/Html/CodeConventions.doc9.html#547
  
  (5) for語句需要循環體。
  假如沒有{}的話,for語句只會執行一次!
  錯誤示例:
  for (i = 0; i < 10; i++) ;
  System.out.println (i);
  這里print() 只會執行一次。
  正確:
  for (i = 0; i < 10; i++) { // FIXED
  System.out.println (i);
  }
  
  (5) 不要把方法定義成main().
  在java里,main()方法是一個非凡的方法。所以在自己定義方法的時候不要定義這樣的名字,以免引起混擾。
  
  (6)不要直接或者間接的定義'Error'和'Throwable'的子類
  'java.lang.Error'只在JVM出現反常的時候覆蓋這個方法,假如你定義了直接或者不直接的類繼續了類'Error',也就指出了這個錯誤是JVM內部的,而不是這個類的。所以對于java編譯器來說是不可見的,這樣就不能檢查錯誤的異常處理了。
  'java.lang.Throwable'是'java.lang.Exception'和'java.lang.Error'的上級類,用戶假如象定義異常類的話應該繼續'java.lang.Exception'。
  錯誤示例:public class ABC extends Error
  正確:public class ABC extends Exception
  
  (7)有關"switch"語句里面的"case"問題
  最好在每一個 “case”里都定義一個”return”或者“break”來控制不要走到下面的 “case”里去。假如一個”case”語句在代碼的最后沒有一個”break”或者”return”句,程序就會走到下一個”case”。假如這個”case”是最后一個的話,那就沒什么問題,假如后面還有”case” 的話,看起來就不太安全了。
  錯誤示例:
  switch (i) {
  case 1:
  x = 10;
  break;
  case 2:
  x = 20;
  default:
  a = 40;
  break;
  正確:
  switch (i) {
  case 1:
  x = 10;
  break;
  case 2: // VIOLATION
  x = 20;
  break;
  default:
  x = 40;
  break;
  
  (8)建議不要使用'System.getenv ()'
  不建議使用'System.getenv ()',這個方法看起來很好用,不過并不是所有的系統都有環境變量的。不用這個方法也可能帶來一些不方便。
  錯誤示例:
  void method (String name) {
  System.getenv (name); // 可以用其他方法來代替
  }
  假如不用這個方法,我們可以用其它的方法來代替。比如:'System.getProperty ()’,'getTypeName ()'等,這也可以找到java的系統屬性。
  參考:David Flanagan: "Java in a Nutshell". O'Reilly
  November, 1999: Third Edition, pp.190-192
  
  (9)不要使用’/n’或者'/r'來分行
  這兩個標記看來很普遍,非凡是’/n’。我們經常用來作為分行用。但是不同的系統用不同的分行字符,所以這些字符在某些意義上違反了java的平臺無關性。
  錯誤示例:
  System.out.println("Hello/n" + name);
  我們可以用其它的一些方法來代替,比如println(),這個方法在不同的系統平臺上都起到相同的作用。后者推薦大家用這個方法:System.getProperty("line.separator")
  參考:David Flanagan: "Java in a Nutshell". O'Reilly,
  November 1999: Third Edition, pp. 191-192
  
  (10) 使所有的內部類"private".
  Java答應一個類包含另外一個類,帶是Java byte code沒有這個概念。類被編譯器解釋成package-private類。從更深的程度來說,包含類的任何內部私有對象能被內部類訪問的也能被同一個包內的其他類訪問。
  錯誤示例:
  public class INNER {
  class INNER_Class {
  void setValue(int i) {
  _value = i; // 現在包就可以訪問了
  }
  }
  private int _value;
  }
  所以需要加上private class INNER_Class
  參考:Statically Scanning Java Code: Finding Security Vulnerabilities.
  John Viega, Gary McGraw, Tom Mutdosch, and Edward W. Felten
  IEEE SOFTWARE September/October 2000
  
  (11)不要使接口序列化
  假如一個字節數組包含了一個被序列化的對象。攻擊者就能讀到這個對象的內部狀態合字段(包括private的)。
  錯誤示例:
  public interface sample extends java.io.Serializable

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 闸北区| 清水河县| 眉山市| 常德市| 资兴市| 隆安县| 高淳县| 清远市| 斗六市| 抚松县| 丽水市| 如东县| 寿阳县| 阿拉善右旗| 东城区| 威信县| 瑞金市| 尼勒克县| 井研县| 额济纳旗| 楚雄市| 光泽县| 巴南区| 天津市| 巨鹿县| 思南县| 玉山县| 灌云县| 海兴县| 邳州市| 大新县| 错那县| 汝南县| 陆河县| 东源县| 全椒县| 会理县| 姚安县| SHOW| 威海市| 阿拉善盟|