利用java反射调用类的的私有方法

    今天和一位朋友谈到父类私有方法的调用问题,本来以为利用反射很轻松就可以实现,因为在反射看来根本不区分是否是private的,没有想到调用本身的私有方法是可以的,但是调用父类的私有方法则不行,后来纠其原因很有可能是因为getDeclaredMethod方法和getMethod方法并不会查找父类的私有方法,于是只好自己写递归了,经过尝试果然如此。把代码放出来方便更多人。这段代码可以解决很多实际问题,不过利用反射来做的话性能不会太好。

package com.syj.util.reflect;

import java.lang.reflect.Method;

/**
 * 

* Title: 私有方法调用工具类 *

* *

* Description:利用java反射调用类的的私有方法 *

* *

* Copyright: Copyright (c) 2007 *

* * @author 孙钰佳 * @main sunyujia@yahoo.cn * @date Jun 1, 2008 10:18:58 PM */ public class PrivateUtil { /** * 利用递归找一个类的指定方法,如果找不到,去父亲里面找直到最上层Object对象为止。 * * @param clazz * 目标类 * @param methodName * 方法名 * @param classes * 方法参数类型数组 * @return 方法对象 * @throws Exception */ public static Method getMethod(Class clazz, String methodName, final Class[] classes) throws Exception { Method method = null; try { method = clazz.getDeclaredMethod(methodName, classes); } catch (NoSuchMethodException e) { try { method = clazz.getMethod(methodName, classes); } catch (NoSuchMethodException ex) { if (clazz.getSuperclass() == null) { return method; } else { method = getMethod(clazz.getSuperclass(), methodName, classes); } } } return method; } /** * * @param obj * 调整方法的对象 * @param methodName * 方法名 * @param classes * 参数类型数组 * @param objects * 参数数组 * @return 方法的返回值 */ public static Object invoke(final Object obj, final String methodName, final Class[] classes, final Object[] objects) { try { Method method = getMethod(obj.getClass(), methodName, classes); method.setAccessible(true);// 调用private方法的关键一句话 return method.invoke(obj, objects); } catch (Exception e) { throw new RuntimeException(e); } } public static Object invoke(final Object obj, final String methodName, final Class[] classes) { return invoke(obj, methodName, classes, new Object[] {}); } public static Object invoke(final Object obj, final String methodName) { return invoke(obj, methodName, new Class[] {}, new Object[] {}); } /** * 测试反射调用 * * @param args */ public static void main(String[] args) { PrivateUtil.invoke(new B(), "printlnA", new Class[] { String.class }, new Object[] { "test" }); PrivateUtil.invoke(new B(), "printlnB"); } } class A { private void printlnA(String s) { System.out.println(s); } } class B extends A { private void printlnB() { System.out.println("b"); } }

 


程序的输出结果为
test
b
说明private方法调用成功了不管是自己的私有方法还是父类的私有方法。

  • 2
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值