Java的類庫日益龐大,所包含的類和接口也不計其數。但其中有一些非常重要的類和接口,是Java類庫中的核心部分。常見的有String、Object、Class、Collection、ClassLoader...,熟悉這些類是學好Java的基礎。而這些類一般不容易理解,需要做深入的研究和實踐才能掌握。下面是我對這些類理解和使用的一些總結。歡迎你在閱讀后將你寶貴的意見和讀后感留下!
本文引用地址://www.einuk.cn/emb/Column/7448.html
Java程序在運行時,Java運行時系統一直對所有的對象進行所謂的運行時類型標識。這項信息紀錄了每個對象所屬的類。虛擬機通常使用運行時類型信息選準正確方法去執行,用來保存這些類型信息的類是Class類。Class類封裝一個對象和接口運行時的狀態,當裝載類時,Class類型的對象自動創建。
Class 沒有公共構造方法。Class 對象是在加載類時由 Java 虛擬機以及通過調用類加載器中的 defineClass 方法自動構造的,因此不能顯式地聲明一個Class對象。
虛擬機為每種類型管理一個獨一無二的Class對象。也就是說,每個類(型)都有一個Class對象。運行程序時,Java虛擬機(JVM)首先檢查是否所要加載的類對應的Class對象是否已經加載。如果沒有加載,JVM就會根據類名查找.class文件,并將其Class對象載入。
基本的 Java 類型(boolean、byte、char、short、int、long、float 和 double)和關鍵字 void 也都對應一個 Class 對象。
每個數組屬于被映射為 Class 對象的一個類,所有具有相同元素類型和維數的數組都共享該 Class 對象。
一般某個類的Class對象被載入內存,它就用來創建這個類的所有對象。
一、如何得到Class的對象呢?
有三種方法可以的獲取:
1、調用Object類的getClass()方法來得到Class對象,這也是常見的產生Class對象的方法。例如:
MyObject x;
Class c1 = x.getClass();
2、使用Class類中的靜態forName()方法獲得與字符串對應的Class對象。例如:
Class c2=Class.forName("Employee"),Employee必須是接口或者類的名字。
3、獲取Class類型對象的第三個方法非常簡單。如果T是一個Java類型,那么T.class就代表了匹配的類對象。例如
Class cl1 = Manager.class;
Class cl2 = int.class;
Class cl3 = Double[].class;
注意:Class對象實際上描述的只是類型,而這類型未必是類或者接口。例如上面的int.class是一個Class類型的對象。由于歷史原因,數組類型的getName方法會返回奇怪的名字。
二、Class類的常用方法
1、getName()
一個Class對象描述了一個特定類的屬性,Class類中常用的方法getName以 String 的形式返回此 Class 對象所表示的實體(類、接口、數組類、基本類型或 void)名稱。
2、newInstance()
Class還有一個有用的方法可以為類創建一個實例,這個方法叫做newInstance()。例如:
x.getClass.newInstance(),創建了一個同x一樣類型的新實例。newInstance()方法調用默認構造器(無參數構造器)初始化新建對象。
3、getClassLoader()
返回該類的類加載器。
4、getComponentType()
返回表示數組組件類型的 Class。
5、getSuperclass()
返回表示此 Class 所表示的實體(類、接口、基本類型或 void)的超類的 Class。
6、isArray()
判定此 Class 對象是否表示一個數組類。
三、Class的一些使用技巧
1、forName和newInstance結合起來使用,可以根據存儲在字符串中的類名創建對象。例如
Object obj = Class.forName(s).newInstance();
2、虛擬機為每種類型管理一個獨一無二的Class對象。因此可以使用==操作符來比較類對象。例如:
if(e.getClass() == Employee.class)...
四.典型例題
1.將所有String類型的成員變量里的b改成a。
1 import java.lang.reflect.Field;
2 public class TestReflect {
3 public static void main(String[] args) throws SecurityException, NoSuchMethodException, NoSuchFieldException, IllegalArgumentException, Exception {
4 ReflectPointer rp1 = new ReflectPointer(3,4);
5 changeBtoA(rp1);
6 System.out.println(rp1);
7
8 }
9
10 private static void changeBtoA(Object obj) throws RuntimeException, Exception {
11 Field[] fields = obj.getClass().getFields();
12
13 for(Field field : fields) {
14 //if(field.getType().equals(String.class))
15 //由于字節碼只有一份,用equals語義不準確
16 if(field.getType()==String.class) {
17 String oldValue = (String)field.get(obj);
18 String newValue = oldValue.replace('b', 'a');
19 field.set(obj,newValue);
20 }
21 }
22 }
23 }
24
25 class ReflectPointer {
26
27 private int x = 0;
28 public int y = 0;
29 public String str1 = "ball";
30 public String str2 = "basketball";
31 public String str3 = "itcat";
32
33 public ReflectPointer(int x,int y) {//alt + shift +s相當于右鍵source
34 super();
35 // TODO Auto-generated constructor stub
36 this.x = x;
37 this.y = y;
38 }
39
40 @Override
41 public String toString() {
42 return "ReflectPointer [str1=" + str1 + ", str2=" + str2 + ", str3="
43 + str3 + "]";
44 }
45 }