Java基礎:反射篇
阿新 • • 發佈:2020-09-19
1.獲得反射物件
package com.cl.reflection; public class Test02 extends Object{ public static void main(String[] args) throws ClassNotFoundException { //通過反射獲取類的Class物件 Class c1=Class.forName("com.cl.reflection.User"); System.out.println(c1); } } //實體類:pojo,entity class User{private String name; private int id; private int age; public User(){ } public User(String name,int id,int age){ this.name=name; this.id=id; this.age=age; } public String getName() { return name; } public void setName(String name) {this.name = name; } public int getId() { return id; } public void setId(int id) { this.id = id; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() {return "User{" + "name='" + name + '\'' + ", id=" + id + ", age=" + age + '}'; } }
2.獲取反射物件的各種方式
package com.cl.reflection; //測試獲取Class類的例項的各種方式 public class Test03 { public static void main(String[] args) throws ClassNotFoundException { Person person=new Student(); System.out.println("這個人是:"+person.name); //方式一:通過物件獲得 Class c1 = person.getClass(); System.out.println(c1.hashCode()); //方式二:forname獲得 Class c2=Class.forName("com.cl.reflection.Student"); System.out.println(c2.hashCode()); //方式三:通過類名,Class獲得 Class c3=Student.class; System.out.println(c3.hashCode()); //方式四:基本內建型別的包裝類都有一個Type屬性 //獲得父類型別 Class c5 = c1.getSuperclass(); System.out.println(c5); } } class Person{ public String name; public Person() { } public Person(String name) { this.name = name; } @Override public String toString() { return "Person{" + "name='" + name + '\'' + '}'; } } class Student extends Person{ public Student(){ this.name="學生"; } } class Teacher extends Person{ public Teacher(){ this.name="老師"; } }
3.所有型別的class類的物件
package com.cl.reflection; import java.lang.annotation.ElementType; //所有型別的class public class Test04 { public static void main(String[] args) { Class c1 = Object.class;//類 Class c2 = Comparable.class;//介面 Class c3=String[].class; Class c4=int[][].class; Class c5=Override.class; Class c6= ElementType.class;//列舉型別 Class c7=Integer.class;//基本資料型別 Class c8=void.class;//void Class c9=Class.class;//Class本身 System.out.println(c1); System.out.println(c2); System.out.println(c3); System.out.println(c4); System.out.println(c5); System.out.println(c6); System.out.println(c7); System.out.println(c8); System.out.println(c9); //只要元素型別和維度一樣,就是同一個Class int[] a=new int[10];//a和b的hashcode碼是一樣的 int[] b=new int[100]; System.out.println(a.getClass().hashCode()); System.out.println(b.getClass().hashCode()); } }
4.類載入記憶體分析
package com.cl.reflection; //類載入記憶體分析 //1.載入:將Class檔案位元組碼內容載入到記憶體中,並將這些靜態資料轉換成方法區的執行時的資料結構 // 讓後生成一個代表這個類的java.lang.Class物件 //2.連結:將Java類的二進位制程式碼合併到JVM的執行狀態之中的過程 //3.初始化:執行類構造器的方法過程 public class Test05 { public static void main(String[] args) { A a=new A(); System.out.println(A.m); } } class A{ static { System.out.println("A類靜態程式碼塊初始化"); m=300; } static int m=100; public A(){ System.out.println("A類的無參構造初始化"); } }
5.測試類什麼時候初始化
package com.cl.reflection; //測試類什麼時候初始化 public class Test06 { static { System.out.println("main 類被載入"); } public static void main(String[] args) throws ClassNotFoundException { //1.主動引用 //Son son = new Son(); //反射也會產生主動引用 //Class.forName("com.cl.reflection.Son"); //不會產生類的引用的方法 //System.out.println(Son.b); Son[] array=new Son[5]; } } class Father{ static int b=2; static { System.out.println("父類被載入"); } } class Son extends Father{ static { System.out.println("子類被載入"); m=300; } static int m=100; static final int M=1; }