經由過程java反射機制靜態挪用某辦法的總結(推舉)。本站提示廣大學習愛好者:(經由過程java反射機制靜態挪用某辦法的總結(推舉))文章只能為提供參考,不一定能成為您想要的結果。以下是經由過程java反射機制靜態挪用某辦法的總結(推舉)正文
以下:
public Object invokeMethod(String className, String methodName, Object[] args) throws Exception{ Class ownerClass = Class.forName(className); Object owner = ownerClass.newInstance(); Class[] argsClass = new Class[args.length]; for (int i = 0, j = args.length; i < j; i++) { argsClass[i] = args[i].getClass(); } Method method = ownerClass.getMethod(methodName, argsClass); return method.invoke(owner, args); }
然則,我們在現實運用中,還會碰著一種情形,傳入的實參和要被挪用的辦法的形參能夠不完整分歧:
好比,在struts1.x中的某個辦法被挪用時刻,它會有HttpServletResponse類型的參數,
我們在tomcat中,request對象的實例實際上是:org.apache.catalina.connector.ResponseFacade
它完成了接口:javax.servlet.http.HttpServletResponse;
假如我們直接把web容器中的request對象當作一個參數,傳入下面的代碼片斷的話, 就有成績,這時候,我們的處置方法是如許的,在action中,辦法普通形如:
public ActionForward query(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
response普通位於第四個,那末我們修正以上的代碼:
把
for (int i = 0, j = args.length; i < j; i++) { argsClass[i] = args[i].getClass(); }
改成:
for (int i = 0, j = args.length; i < j; i++) { if(i == 3){ argsClass[i] = HttpServletResponse.class; } else{ argsClass[i] = args[i].getClass(); } }
以上這篇經由過程java反射機制靜態挪用某辦法的總結(推舉)就是小編分享給年夜家的全體內容了,願望能給年夜家一個參考,也願望年夜家多多支撐。