3 回答

TA貢獻(xiàn)1893條經(jīng)驗(yàn) 獲得超10個(gè)贊
您可以使用反射調(diào)用私有方法。修改已發(fā)布代碼的最后一位:
Method method = object.getClass().getDeclaredMethod(methodName);method.setAccessible(true);Object r = method.invoke(object);
有幾點(diǎn)需要注意。首先,getDeclaredMethod
只會(huì)查找當(dāng)前聲明的方法Class
,而不是從超類型繼承。因此,如有必要,遍歷具體的類層次結(jié)構(gòu)。其次,a SecurityManager
可以防止使用該setAccessible
方法。因此,它可能需要作為PrivilegedAction
(使用AccessController
或Subject
)運(yùn)行。

TA貢獻(xiàn)1780條經(jīng)驗(yàn) 獲得超1個(gè)贊
使用getDeclaredMethod()
獲得的私有方法的對(duì)象,然后使用method.setAccessible()
允許實(shí)際調(diào)用它。

TA貢獻(xiàn)1828條經(jīng)驗(yàn) 獲得超6個(gè)贊
如果方法接受非原始數(shù)據(jù)類型,則可以使用以下方法來(lái)調(diào)用任何類的私有方法:
public static Object genericInvokeMethod(Object obj, String methodName, Object... params) { int paramCount = params.length; Method method; Object requiredObj = null; Class<?>[] classArray = new Class<?>[paramCount]; for (int i = 0; i < paramCount; i++) { classArray[i] = params[i].getClass(); } try { method = obj.getClass().getDeclaredMethod(methodName, classArray); method.setAccessible(true); requiredObj = method.invoke(obj, params); } catch (NoSuchMethodException e) { e.printStackTrace(); } catch (IllegalArgumentException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (InvocationTargetException e) { e.printStackTrace(); } return requiredObj; }
接受的參數(shù)是obj,methodName和參數(shù)。例如
public class Test {private String concatString(String a, String b) { return (a+b);}}
方法concatString可以作為調(diào)用
Test t = new Test(); String str = (String) genericInvokeMethod(t, "concatString", "Hello", "Mr.x");
添加回答
舉報(bào)