1:了解什么是反射機制?
在通常情況下,如果有一個類,可以通過類創建對象;但是反射就是要求通過一個對象找到一個類的名稱;
2:在反射操作中,握住一個核心概念:
一切操作都將使用Object完成,類,數組,的引用都可以使用Object進行接收;
3:Class類:
功能:
通過一個實例化對象,找到一個類的完整信息;
public final class
Class<T>
extends
Object
package cn.itcast;
//聲明X類
class X {
}
public class ClassDemo01 {
public static void main(String[] args) {
//實例化X類對象
X x = new X();
//得到對象所在的類
System. out.println(x.getClass().getName());
}
}
打印結果:cn.itcast.X(包名.類)
1:get.Class()方法:
任何一個類如果沒有聲明繼承自那個父類,默認繼承Object類;
返回Object運行時的類,返回值是Class類,此類就是反射的源頭;
public final
Class<?>
getClass()
2:
getName()方法:
public
String
getName()
以
String 的形式返回此
Class 對象所表示的實體(類、接口、數組類、基本類型或 void)名稱;
3:傳統方式和反射方式:
傳統方式:
引入“包.類”的名稱 ----- 通過new實例化 ------ 創建實例化對象
反射方式:
實例化對象 ----- getClass() ---- 得到完整的“包.類”名稱
4:結論
所有類的對象實際上都是Class類的實例;
package cn.itcast;
public class Person {
private String name;
private int age;
private char sex;
public Person() {
super();
}
public Person(String name, int age, char sex) {
super();
this.name = name;
this.age = age;
this.sex = sex;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public char getSex() {
return sex;
}
public void setSex(char sex) {
this.sex = sex;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + ", sex=" + sex + "]";
}
}
5:創建Class對象的三種方式:
package cn.itcast; public class ClassDemo02 { public static void main(String[] args) { Person p1 = new Person("小明" ,20,'男' ); Person p2 = new Person("小紅" ,23,'女' ); //創建Class對象的方式一:(對象.getClass()) Class class1 = p1.getClass(); System. out.println(p1.getClass().getName()); Class class2 = p2.getClass(); System. out.println(class1 == class2 ); System. out.println("==============================" ); //創建Class對象的方式二:(類.class:需要輸入一個明確的類) Class class3 = Person.class; System. out.println(class1 == class2); System. out.println("==============================" ); //創建Class對象的方式三:(forName():傳入時只需要以字符串的方式傳入即可) //Class.forName()有異常:ClassNotFoundException Class class4 = null; try { class4 = Class. forName("cn.itcast.Person"); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } System. out.println(class4 == class3); } } 結論: Class類不能使用new來實例化對象,代表類的字節碼.相同類別的對象的類字節碼相同 一個Class對象代表着一份字節碼,相同類型的對象得到的字節碼對象是同一個
