JAVA中Object轉String

菜雞03號發表於2016-09-29

java中Object轉String

 

Object轉為String的幾種形式

 在java專案的實際開發和應用中,常常需要用到將物件轉為String這一基本功能。本文將對常用的轉換方法進行一個總結。常用的方法有Object.toString(),(String)要轉換的物件,String.valueOf(Object)等。下面對這些方法一一進行分析。

方法1:採用 Object.toString()方法
請看下面的例子:
Object object = getObject();
System.out.println(object.toString());
在這種使用方法中,因為java.lang.Object類裡已有public方法.toString(),所以對任何嚴格意義上的java物件都可以呼叫此方法。但在使用時要注意,必須保證object不是null值,否則將丟擲NullPointerException異常。採用這種方法時,通常派生類會覆蓋Object裡的toString()方法。

方法2:採用型別轉換(String)object方法
這是標準的型別轉換,將object轉成String型別的值。使用這種方法時,需要注意的是型別必須能轉成String型別。因此最好用instanceof做個型別檢查,以判斷是否可以轉換。否則容易丟擲CalssCastException異常。此外,需特別小心的是因定義為Object 型別的物件在轉成String時語法檢查並不會報錯,這將可能導致潛在的錯誤存在。這時要格外小心。如:
Object obj = new Integer(100);
String strVal = (String)obj;

在執行時將會出錯,因為將Integer型別強制轉換為String型別,無法通過。但是,
Integer obj = new Integer(100);
String strVal = (String)obj;
如是格式程式碼,將會報語法錯誤。
此外,因null值可以強制轉換為任何java類型別,(String)null也是合法的。

方法3:採用String.valueOf(Object)
String.valueOf(Object)的基礎是Object.toString()。但它與Object.toString()又有所不同。在前面方法1的分析中提到,使用第一種時需保證不為null。但採用第三種方法時,將不用擔心object是否為null值這一問題。為了便於說明問題,我們來分析一下相關的原始碼。Jdk裡String.valueOf(Object)原始碼如下:
  /**
   * Returns the string representation of the Object argument.
   *
   * @param  obj  an Object.
   * @return if the argument is null, then a string equal to
   *     "null"; otherwise, the value of
   *     obj.toString() is returned.
   * @see   java.lang.Object.toString()
   */

  public static String valueOf(Object obj) {

    return (obj == null) ? "null" : obj.toString();
}
從上面的原始碼可以很清晰的看出null值不用擔心的理由。但是,這也恰恰給了我們隱患。我們應當注意到,當object為null時,String.valueOf(object)的值是字串"null",而不是null!在使用過程中切記要注意。試想一下,如果我們用
  if(String.valueOf(object)==null)
{
  System.out.println(“傳入的值是null!");
}
這樣的語句將可能會發生什麼問題。再想一下,向控制檯輸出時,在視覺上如下語句在執行的結果上有什麼不同:
System.out.println(String.valueOf(null));
System.out.println(null);
我們看到的輸出將是一模一樣的東西:null,但它們意義相同嗎?

判斷一個字串為空
 s為一個字串,判斷它為空的方法:
if   (null==s ||"".equals(s))   {  
......
  }   
注意:這裡的null==s和"".equals(s)不要寫成s==null和s.equals(s),因為""這個值是已經確定的,預知的,而s是未知的,所以用得不小心的時候s.equals("")就會出現nullpoint異常。在這裡雖然不會,因為前面有if(null==s),但是習慣跟在那裡使用沒有關係的。不一定的equals方法,包括其它很多處理,如果用確定的值處理問題會比未確定的處理少很多bug。

相關文章