① java 反射 Field.set(object,object)方法的含義
person=(Person)Class.forName("Person").newInstance();
② java反射調用屬性的set方法時,若屬性為int類型,會出錯,設置通過get得到的值的getClass為Integer。
Integer可以直接轉成int的啊,int是基本類型,去不是繼承於object,而integer是類才能用getclass方法。獲得之後能夠轉成int型
③ java反射給欄位賦值就是給實體類的set賦值,怎麼做
packagecom.test;
importjava.lang.reflect.Field;
publicclassA{
privateStringname;
publicStringgetName(){
returnname;
}
publicvoidsetName(Stringname){
this.name=name;
}
publicstaticvoidmain(String[]args){
try{
Class<A>c=A.class;
Fieldfield=c.getDeclaredField("name");//獲取欄位
Objectobj=c.newInstance();//實例化對象
field.set(obj,"aaa");//為欄位賦值
System.out.println(field.get(obj));
}catch(Exceptione){
e.printStackTrace();
}
}
}
④ Java反射問題
一個標準的javabean類所有欄位都是私有的.然後提供該欄位的GET,SET.
這個是前提!
1.該欄位的SET 方法 有可能加了攔截代碼.有些值不賦進去.例如你做一個注冊.要填性別的時候就只能填男女.其他不能填的就會用攔截代碼攔截掉.
2.如果你用反射,就有方法直接訪問那個欄位,無論那欄位是否私有.賦值的時候用的是JAVA反射包里Field類(java.lang.reflect.Field)里提供的SET方法其實就相當於直接賦值.不用經過其他攔截代碼.即不用經類本身欄位的SET方法
3.反射的意義體現了它能對項目的曠展性上.
例如你要實例化一個業務類.
普通:Demo d = new Demo();
------------------------------------
反射:Demo d= Class.forName(`類全名`);//可以直接通過類名就實例化一個對象,不用直接NEW
//而類名可以寫在配置文件上面.用IO.讀進來用就可以了.
//這樣寫得話,到時候要升級業務需求的時候,要換一個實現類,就不用其他改動源碼,把新寫好的業類類全名直接寫在配置文件上就可以了
⑤ Java反射機制獲取set()方法 並且為set()方法傳值
Class.getDeclaredMethod()
是獲取這個類中所有的方法,返回的是Method[]如果有參數,第1個是方法名稱,第2個是該方法的所有參數數組,這樣返回的是Method這個對象Method.invoke()
傳入調用方法的類,另一個是調用這個方法所需要的參數,如果該方法沒有參數,可以不填寫,在JDK1,4之前,第2個參數是傳入一個數組的,但是在jdk1.5之後,可以不傳數組,多個參數用逗號隔開
不知道你聽明白沒
⑥ Java反射賦值會調用set方法嗎
不會。set/get方法只是javaBean的規范,用來統一管理Bean屬性的賦值操作。
⑦ java invoke 反射的使用方法
你這個類是一個嚴格的JavaBean格式。。所以先可以獲得屬性。。然後獲得讀寫方法。。然後寫值。。讀值。。hibernate其實也就是採用的這種差不多的方式。。
import java.beans.PropertyDescriptor;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
public class ReflectTest {
/**
* @param args
*/
public static void main(String[] args) throws Exception {
Class clazz = Class.forName("TaskProvidePropsList");//這里的類名是全名。。有包的話要加上包名
Object obj = clazz.newInstance();
Field[] fields = clazz.getDeclaredFields();
//寫數據
for(Field f : fields) {
PropertyDescriptor pd = new PropertyDescriptor(f.getName(), clazz);
Method wM = pd.getWriteMethod();//獲得寫方法
wM.invoke(obj, 2);//因為知道是int類型的屬性,所以傳個int過去就是了。。實際情況中需要判斷下他的參數類型
}
//讀數據
for(Field f : fields) {
PropertyDescriptor pd = new PropertyDescriptor(f.getName(), clazz);
Method rM = pd.getReadMethod();//獲得讀方法
Integer num = (Integer) rM.invoke(obj);//因為知道是int類型的屬性,所以轉換成integer就是了。。也可以不轉換直接列印
System.out.println(num);
}
}
}
⑧ java反射機制詳解
反射就是把Java的各種成分映射成相應的Java類。
Class類的構造方法是private,由JVM創建。
反射是java語言的一個特性,它允程序在運行時(注意不是編譯的時候)來進行自我檢查並且對內部的成員進行操作。例如它允許一個java的類獲取他所有的成員變數和方法並且顯示出來。Java 的這一能力在實際應用中也許用得不是很多,但是在其它的程序設計語言中根本就不存在這一特性。例如,Pascal、C 或者 C++ 中就沒有辦法在程序中獲得函數定義相關的信息。(來自Sun)
JavaBean 是 reflection 的實際應用之一,它能讓一些工具可視化的操作軟體組件。這些工具通過 reflection 動態的載入並取得 Java 組件(類) 的屬性。
反射是從1.2就有的,後面的三大框架都會用到反射機制,涉及到類"Class",無法直接new CLass(),其對象是內存里的一份位元組碼.
Class 類的實例表示正在運行的 Java 應用程序中的類和介面。枚舉是一種類,注釋是一種介面。每個數組屬於被映射為 Class 對象的一個類,所有具有相同元素類型和維數的數組都共享該 Class 對象。
基本的 Java類型(boolean、byte、char、short、int、long、float 和 double)和關鍵字 void 也表示為 Class 對象。Class 沒有公共構造方法。
Class 對象是在載入類時由 Java 虛擬機以及通過調用類載入器中的 defineClass 方法自動構造的。
Person p1 = new Person();
//下面的這三種方式都可以得到位元組碼
CLass c1 = Date.class();
p1.getClass();
//若存在則載入,否則新建,往往使用第三種,類的名字在寫源程序時不需要知道,到運行時再傳遞過來
Class.forName("java.lang.String");
Class.forName()位元組碼已經載入到java虛擬機中,去得到位元組碼;java虛擬機中還沒有生成位元組碼 用類載入器進行載入,載入的位元組碼緩沖到虛擬機中。
另外,大家可以關注微信公眾號Java技術棧回復:JVM,獲取我整理的系列JVM教程,都是干貨。
考慮下面這個簡單的例子,讓我們看看 reflection 是如何工作的。
import java.lang.reflect.*;
public class DumpMethods {
public static void main(String args[]) {
try {
Class c = Class.forName("java.util.Stack");
Method m[] = c.getDeclaredMethods();
for (int i = 0; i < m.length; i++)
System.out.println(m[i].toString());
}
catch (Throwable e){
System.err.println(e);
}
}
}
public synchronized java.lang.Object java.util.Stack.pop()
public java.lang.Object java.util.Stack.push(java.lang.Object)
public boolean java.util.Stack.empty()
public synchronized java.lang.Object java.util.Stack.peek()
public synchronized int java.util.Stack.search(java.lang.Object)
這樣就列出了java.util.Stack 類的各方法名以及它們的限制符和返回類型。這個程序使用 Class.forName 載入指定的類,然後調用 getDeclaredMethods 來獲取這個類中定義了的方法列表。java.lang.reflect.Methods 是用來描述某個類中單個方法的一個類。
以下示例使用 Class 對象來顯示對象的類名:
void printClassName(Object obj) {
System.out.println("The class of " + obj +
" is " + obj.getClass().getName());
}
還可以使用一個類字面值(JLS Section 15.8.2)來獲取指定類型(或 void)的 Class 對象。例如:
System.out.println("The name of class Foo is: "+Foo.class.getName());
在沒有對象實例的時候,主要有兩種辦法。
//獲得類類型的兩種方式
Class cls1 = Role.class;
Class cls2 = Class.forName("yui.Role");
注意第二種方式中,forName中的參數一定是完整的類名(包名+類名),並且這個方法需要捕獲異常。現在得到cls1就可以創建一個Role類的實例了,利用Class的newInstance方法相當於調用類的默認的構造器。
Object o = cls1.newInstance();
//創建一個實例
//Object o1 = new Role(); //與上面的方法等價
⑨ Java反射機制獲取set()方法 並且為set()方法傳值
Class.getDeclaredMethod() 是獲取這個類中所有的方法,返回的是Method[]如果有參數,第1個是方法名稱,第2個是該方法的所有參數數組,這樣返回的是Method這個對象Method.invoke() 傳入調用方法的類,另一個是調用這個方法所需要的參數,如果該方法沒有參數,可以不填寫,在JDK1,4之前,第2個參數是傳入一個數組的,但是在jdk1.5之後,可以不傳數組,多個參數用逗號隔開 不知道你聽明白沒
⑩ java反射 和資料庫數據類型
這的關鍵在於你的columnValue的數據類型,你應該傳入的是Timestamp,而這個set方法需要的是Datetime類型