Java學習筆記:關於.getClass()和.class的區別

曾經被.class和.getClass()的區別困擾過,通過一番學習纔有所發現,最明顯的區別就是.getClass()是一個對象實例的方法,只有對象實例纔有這個方法,具體的類是沒有的。類的Class類實例是經過.class得到的,顯然,類沒有.getClass()方法。不過要談到二者的區別,還要從Java反射提及。
Java反射學習
所謂反射,能夠理解爲在運行時期獲取對象類型信息的操做。傳統的編程方法要求程序員在編譯階段決定使用的類型,可是在反射的幫助下,編程人員能夠動態獲取這些信息,從而編寫更加具備可移植性的代碼。嚴格地說,反射並不是編程語言的特性,由於在任何一種語言均可以實現反射機制,可是若是編程語言自己支持反射,那麼反射的實現就會方便不少。
1,得到類型類
咱們知道在Java中一切都是對象,咱們通常所使用的對象都直接或間接繼承自Object類。Object類中包含一個方法名叫getClass,利用這個方法就能夠得到一個實例的類型類。類型類指的是表明一個類型的類,由於一切皆是對象,類型也不例外,在Java使用類型類來表示一個類型。全部的類型類都是Class類的實例。例如,有以下一段代碼:java

A a = new A();  
  
if(a.getClass()==A.class) {  
  
      System.out.println("equal");  
  
} else {  
  
      System.out.println("unequal");  
  
}  
輸出equal;  程序員

能夠看到,對象a是A的一個實例,A是某一個類,在if語句中使用a.getClass()返回的結果正是A的類型類,在Java中表示一個特定類型的類型類能夠用「類型.class」的方式得到,由於a.getClass()得到是A的類型類,也就是A.class,所以上面的代碼執行的結果就是打印出「equal」。特別注意的是,類型類是一一對應的,父類的類型類和子類的類型類是不一樣的,所以,假設A是B的子類,那麼以下的代碼將獲得「unequal」的輸出:編程

A a = new A();  
  
if(a.getClass()==B.class) {  
  
        System.out.println("equal");  
  
}  else {  
          
          System.out.println("unequal");  
}  
輸出unequal;  數組

所以,若是你知道一個實例,那麼你能夠經過實例的「getClass()」方法得到該對象的類型類,若是你知道一個類型,那麼你能夠使用「.class」的方法得到該類型的類型類。
2,得到類型的信息
在得到類型類以後,你就能夠調用其中的一些方法得到類型的信息了,主要的方法有:
getName():String:得到該類型的全稱名稱。
getSuperClass():Class:得到該類型的直接父類,若是該類型沒有直接父類,那麼返回null。
getInterfaces():Class[]:得到該類型實現的全部接口。
isArray():boolean:判斷該類型是不是數組。
isEnum():boolean:判斷該類型是不是枚舉類型。
isInterface():boolean:判斷該類型是不是接口。
isPrimitive():boolean:判斷該類型是不是基本類型,便是否是int,boolean,double等等。
isAssignableFrom(Classcls):boolean:判斷這個類型是不是類型cls的父(祖先)類或父(祖先)接口。
getComponentType():Class:若是該類型是一個數組,那麼返回該數組的組件類型。
此外還能夠進行類型轉換這類的操做,主要方法有:
asSubclass(Class clazz):Class:將這個類型編程語言


同時,尚學堂陳老師還從其餘資料上找到的如下內容一併分享:
一、出現的時期不一樣:Class.forName(),getClass()在運行時加載;Class.class是在編譯器加載,即.class是靜態加載,.getClass()是動態加載。這裏有些個疑問?Class.forName("XXX")這方法是動態加載class,先把類文件加載進來,再使用.newInstance()時建立了一個對象。學習

new ClassName(),就是所謂的靜態加載,
Class.forName("ClassName"),就是所謂的動態加載。對象

區別在於「靜態加載」的類在編譯的時候就要提供,而動態加載的類在源程序編譯時能夠缺席。繼承

Class.forName(xxx.xx.xx) 返回的是一個類, .newInstance() 後才建立一個對象 Class.forName(xxx.xx.xx);的做用是要求JVM查找並加載指定的類,也就是說JVM會執行該類的靜態代碼段。接口

二、舉個例子,Iterator it = s.iterator();獲得的it的真正類型是KeyIterator,是Iterator的子類,按常理來講應該能夠執行next()方法,可是值得注意的是,KeyIterator是hashmap的內部類,JAVA給的提示是cannot access a member of class java.util.HashMap$KeyIterator withmodifiers "public"
從上面的那些例子上也能看出,除內部類外的其餘類的應用上.class功能徹底等於.getClass()!只是一個是用類直接得到的,一個是用實例得到的。
 get

相關文章
相關標籤/搜索