亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

反射——Java高級開發必須懂的

難度入門
時長 1小時20分
學習人數
綜合評分9.67
760人評價 查看評價
9.9 內容實用
9.6 簡潔易懂
9.5 邏輯清晰
  • Java反射機制——獲取成員變量&構造函數 一、成員變量是java.lang.reflect.Field的對象 1、Field類封裝了關于成員變量的操作 2、Field[] fs = c.getFields()方法獲取所有public的成員變量Field[]信息 3、c.getDeclaredFields獲取的是該類自己聲明的成員變量信息 4、field.getType()獲得成員類型的類類型 5、field.getName()獲得成員的名稱 二、構造函數是java.lang.Constructor類的對象 1、通過Class.getConstructor()獲得Constructor[]所有公有構造方法信息 2、建議getDeclaredConstructors()獲取自己聲明的構造方法 3、Constructor.getName():String 4、Constructor.getParameterTypes():Class[] 成員變量也是對象,是java.lang.reflect.Field的對象; 反射——獲取成員變量的信息 1.Class c = obj.getClass(); Field[] fs = c.getFields(); 2.獲取成員變量: 獲取成員變量的類型的類類型Class fieldType = field.getType();——>獲取成員變量的類型的名字fieldType.getName();——>獲取成員變量的名稱getName() 反射——獲取構造函數的信息 1.Class c = obj.getClass(); Constructor[] cs = c.getConstructors(); 2.獲取構造函數的參數列表,得到的是參數列表的類型的類類型Class[] paramTypes =constructor.getParammeterTypes();——>獲取參數類型的名稱paramTypes.getName();
    查看全部
  • 獲取方法信息: 基本數據類型,void關鍵字都存在類類型 class.getMethods()方法獲取是該類的所有public方法,包括從父類繼承的方法; class.getDeclareMethods()方法獲取該類自行聲明的所有方法,不論訪問權限; method.getName()獲取方法名 method.getReturnType()獲取方法的返回值 method.getParameterTypes(),獲取方法的參數類型的類類型數組class[] 三獲取方法信息: 一、基本的數據類型,void關鍵字等都存在類類型 Class c = 基類.class (int,String,double,void等) 二、Class類的基本API操作的 1、c.getName()可以獲取類的名稱 2、c.getSimpleName();//不包含包名的類的名稱 3、c.getMethods()獲取類的【public方法】集合,【包括繼承來的】 ***注意【所有方法都是Method類的對象】 4、c.getDeclaredMethods()獲取的是所有該類【自己聲明】的方法,【不問訪問權限】 三、Method類提供了一些操作方法的方法 1、.getReturnType()得到該方法的返回值類型的類類型(class),如int.class String.class 2、.getName()得到方法的名稱 3、.getParameterTypes()獲得參數列表類型的類類型,如參數為(int,int)則得到 Class c1 = int.class; int的類類型 Class c2 = String.class; String類的類類型 String類字節碼 Class c3 = double.class; double這個數據類類型的字節碼表示方式 Class c4 = Double.class; Double這個類的類類型字節碼表示方式 Class c5 = void.class; 表達了void這個類的類類型 getName為這個類的類類型的具體名稱 c1.getName ---> int c2.getName ---> java.lang.String 類的全稱 c2.getSimpleName ---> String 不包含包名的類的名稱
    查看全部
  • new創建對象是靜態加載類,在編譯時進行加載,如果程序中其他的類有問題,那么沒有問題的類也是無法執行的 解決這個問題可以使用動態加載 Word w=new Word();靜態加載 Class c=Class.forName(類的絕對路徑);動態加載 c叫做類的類類型,也可以通過類類型創建實例 c.newInstance(); 功能性的類最好使用動態加載,而不是靜態加載。動態加載類指的是程序運行時加載類,而靜態加載指的是編譯時加載類,編譯時加載的缺點是程序中所有的功能都不能有差錯,否則的話程序就不能用了,而動態加載類的好處就是我們需要使用哪一個類虛擬機就會動態加載根據我們的需要動態的加載這個類,這樣程序的使用就不會受到其他的影響
    查看全部
  • 萬事萬物皆對象 類(class)也是一個對象
    查看全部
    0 采集 收起 來源:Class類的使用

    2017-10-20

  • new 創建對象是靜態加載類,在編譯時刻就需要加載所有可能使用到的類。
    查看全部
  • 1)Foo類的對象是 foo1 Class c2 = foo1.getClass() --->已知該類的對象,通過該類的對象通過getClass方 法獲取Foo類的類類型 2)Foo類的類類型c1指的是Class的對象 Class c1 = Foo.class; 3)一個類只可能是Class類的一個實例對象 4)我們可以通過類的類類型來創建該類的實例對象 Foo foo = (Foo)c1.newInstance();
    查看全部
    0 采集 收起 來源:Class類的使用

    2018-03-22

  • 編譯時刻加載類是靜態加載類,運行時刻加載類是動態加載類
    查看全部
  • 提綱.
    查看全部
    0 采集 收起 來源:Class類的使用

    2017-10-13

  • class對象三種獲取方式 1.Class c1= A.class; 2.Class c2=a.getClass() 3.Class c3 = forNameClass(pakcage.A) 反射機制是在編譯后的 所以可以繞過標準 所有的new 對象都是靜態編譯過程,就是必須編譯時會檢查 invoke方法是反射操作的核心 Mothed m = c1.getMethod(方法名 ,參數列表) m.invoke(代理的對象, 參數) 反射是繞過編譯的。 集合的泛型只為了防止錯誤輸入,編譯階段有效,繞過編譯,使用反射是不會控制集合中的數據類型的。 方法的反射使用: Class c1=對象a.getClass() Method m = c1.getMethod(方法名,參數列表) Object o =m.invoke(對象a,參數列表,可以一一列舉,也可以用數組)
    查看全部
  • 方法的反射操作:用method方法對象a來調用方法a(相當于實例一個類A對象,再A.a();) A a= new A(); Class at = a.getClass(); Method m = at.getMethod("print",int.class,int.class);//print(int a,int b){println(a+b);} m.invoke(a,1,2); 結果為3
    查看全部
  • 方法的反射: 1.獲取A類中的print(int,int)方法: ①要獲取一個方法就是獲取類的信息,獲取類的信息首先要獲取類的類類型 A a1=new A(); Class c= a1.getClass(); ②獲取方法 由名稱和參數列表來決定,getMethod獲取的是public方法,getDelcaredMethod獲取自己聲明的方法 Method m =c.getMethod(methodName,paramtypes);//paramtypes可以用數組的形式 表示new Class[]{int.class,int.class},也可以直接列舉類類型 2.方法的反射操作:是用m對象來進行方法調用,和a1.print(10,20)調用的方法相同 m.invoke(a1,new Object[]{10,20}) Object o=m.invoke(對象名,參數);//方法如果沒有返回值返回null,如果有返回值返回具體值,參數可用數組的方式表示,也可以直接列舉,沒有參數就不寫 public Class A{ public void print(){}; public void Print(Sting a,String b){} public void Print(int a,int b){}; } public Class B{ public static void main(String[] args){ A a1 = new A(); Class c= a1.getclass; Method getMet=c.getMethod("print",String.class,String.class); Object obj=getMet.invoke(a1,"df","df"); } }
    查看全部
  • Java反射機制——獲取成員變量&構造函數 一、成員變量是java.lang.reflect.Field的對象 1、Field類封裝了關于成員變量的操作 2、Field[] fs = c.getFields()方法獲取所有public的成員變量Field[]信息 3、c.getDeclaredFields獲取的是該類自己聲明的成員變量信息 4、field.getType()獲得成員類型的類類型 5、field.getName()獲得成員的名稱 二、構造函數是java.lang.Constructor類的對象 1、通過Class.getConstructor()獲得Constructor[]所有公有構造方法信息 2、建議getDeclaredConstructors()獲取自己聲明的構造方法 3、Constructor.getName():String 4、Constructor.getParameterTypes():Class[] 成員變量也是對象,是java.lang.reflect.Field的對象; 反射——獲取成員變量的信息 1.Class c = obj.getClass(); Field[] fs = c.getFields(); 2.獲取成員變量: 獲取成員變量的類型的類類型Class fieldType = field.getType();——>獲取成員變量的類型的名字fieldType.getName();——>獲取成員變量的名稱getName() 反射——獲取構造函數的信息 1.Class c = obj.getClass(); Constructor[] cs = c.getConstructors(); 2.獲取構造函數的參數列表,得到的是參數列表的類型的類類型Class[] paramTypes =constructor.getParammeterTypes();——>獲取參數類型的名稱paramTypes.getName();
    查看全部
  • 獲取方法信息: 基本數據類型,void關鍵字都存在類類型 class.getMethods()方法獲取是該類的所有public方法,包括從父類繼承的方法; class.getDeclareMethods()方法獲取該類自行聲明的所有方法,不論訪問權限; method.getName()獲取方法名 method.getReturnType()獲取方法的返回值 method.getParameterTypes(),獲取方法的參數類型的類類型數組class[] 三獲取方法信息: 一、基本的數據類型,void關鍵字等都存在類類型 Class c = 基類.class (int,String,double,void等) 二、Class類的基本API操作的 1、c.getName()可以獲取類的名稱 2、c.getSimpleName();//不包含包名的類的名稱 3、c.getMethods()獲取類的【public方法】集合,【包括繼承來的】 ***注意【所有方法都是Method類的對象】 4、c.getDeclaredMethods()獲取的是所有該類【自己聲明】的方法,【不問訪問權限】 三、Method類提供了一些操作方法的方法 1、.getReturnType()得到該方法的返回值類型的類類型(class),如int.class String.class 2、.getName()得到方法的名稱 3、.getParameterTypes()獲得參數列表類型的類類型,如參數為(int,int)則得到 Class c1 = int.class; int的類類型 Class c2 = String.class; String類的類類型 String類字節碼 Class c3 = double.class; double這個數據類類型的字節碼表示方式 Class c4 = Double.class; Double這個類的類類型字節碼表示方式 Class c5 = void.class; 表達了void這個類的類類型 getName為這個類的類類型的具體名稱 c1.getName ---> int c2.getName ---> java.lang.String 類的全稱 c2.getSimpleName ---> String 不包含包名的類的名稱
    查看全部
  • new創建對象是靜態加載類,在編譯時進行加載,如果程序中其他的類有問題,那么沒有問題的類也是無法執行的 解決這個問題可以使用動態加載 Word w=new Word();靜態加載 Class c=Class.forName(類的絕對路徑);動態加載 c叫做類的類類型,也可以通過類類型創建實例 c.newInstance(); 功能性的類最好使用動態加載,而不是靜態加載。動態加載類指的是程序運行時加載類,而靜態加載指的是編譯時加載類,編譯時加載的缺點是程序中所有的功能都不能有差錯,否則的話程序就不能用了,而動態加載類的好處就是我們需要使用哪一個類虛擬機就會動態加載根據我們的需要動態的加載這個類,這樣程序的使用就不會受到其他的影響
    查看全部
  • 1)在面向對象的世界里,萬事萬物皆對象。(靜態成員、普通數據類型) 類是對象,類是java.lang.Class類的實例對象 2)這個對象的表示方式有三種: 第一種表示方式: Class c1 = Foo.class;//任何一個類都有一個隱含的靜態成員變量class 第二種表示方式: Class c2 = foo1.getClass();//已知該類的對象,通過getClass方法得到這個實例類的class(類類型) 第三種表達方式 Class c3 = Class.forName("imooc.reflect.Foo"); 3) <可以通過類類型創建該類的類對象> Class c1 = Foo.class;//c1就是類類型 Foo foo=(Foo)c1.newInstance();
    查看全部
    0 采集 收起 來源:Class類的使用

    2018-03-22

舉報

0/150
提交
取消
課程須知
童鞋們,學習本課程前需要熟悉Java面向對象的思想,并能掌握Java IO輸入輸出流、集合和泛型等知識??蓞⒖寄秸n網Java入門的一、二、三季以及我的文件我做主——Java IO流課程。
老師告訴你能學到什么?
1、能夠理解并應用反射機制。 2、能夠了解反射機制在集合泛型中的應用。 3、有利于更好的學習框架等Java高級技術。

微信掃碼,參與3人拼團

微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

友情提示:

您好,此課程屬于遷移課程,您已購買該課程,無需重復購買,感謝您對慕課網的支持!