method.invoke()和invoke()简单理解

method.invoke()和invoke()简单理解首先说下作用,method.invoke(Objectobj,Objectargs[])的作用就是调用method类代表的方法,其中obj是对象名,args是传入method方法的参数举个例子:如果接口中没有close方法,但是实现类中提供了close,那么就可以用反射来处理,调用实现类的close方法invoke()方法接收的参数必须为对象,如果参数为基本类型数据,必须转换为相应的包…

首先说下作用,method.invoke(Object obj,Object args[])的作用就是调用method类代表的方法,其中obj是对象名,args是传入method方法的参数

举个例子:如果接口中没有close方法,但是实现类中提供了close,那么就可以用反射来处理,调用实现类的close方法

invoke()方法接收的参数必须为对象,如果参数为基本类型数据,必须转换为相应的包装类型的对象。

invoke()方法的返回值总是对象,如果实际被调用的方法的返回类型是基本类型数据,那么invoke()方法会把它转换为相应的包装类型的对象,再将其返回.

有四种获得method对象的方法,返回结果是method对象,或者说是 方法的全限定名
  一共有4种方法,全部都在Class类中:
    - getMethods(): 获得类的public类型的方法
    - getMethod(String name, Class[] params): 获得类的特定方法,name参数指定方法的名字,params参数指定方法的参数类型
    - getDeclaredMethods(): 获取类中所有的方法(public、protected、default、private)
    - getDeclaredMethod(String name, Class[] params): 获得类的特定方法,name参数指定方法的名字,params参数指定方法的参数类型

另外关于代理类,以下Proxy.newProxyInstance的相关内容 是整理自B站的一个视频,

链接如下:https://www.bilibili.com/video/av15369076?p=19

Proxy.newProxyInstance

 *         参数1:loader ,类加载器,动态代理类 运行时创建,任何类都需要类加载器将其加载到内存。

 *                一般情况:方式1:当前类.class.getClassLoader();

 *                                方式2:目标类实例.getClass().get…

 *         参数2:Class[] interfaces 代理类需要实现的所有接口

 *                方式1:目标类实例.getClass().getInterfaces()  ;但是需要注意:这种方法只能获得自己接口,不能获得父元素接口

 *                方式2:new Class[]{UserService.class}  

 *                例如:jdbc 驱动  –> DriverManager  不能获得接口 Connection

 *         参数3:InvocationHandler  处理类,接口,必须进行实现类,一般采用匿名内部

 *         提供invoke 方法,代理类的每一个方法执行时,都将调用一次invoke

 *         参数31:Object proxy :代理对象

 *         参数32:Method method : 代理对象当前执行的方法的描述对象(反射)

*                  执行方法名:method.getName()

*           参数33:Object[] args :方法实际参数

Invoke方法内部:

*                  执行方法:method.invoke(对象,实际参数)

 

public class MyBeanFactory {
	
	public static UserService createService(){
		//1 目标类
		final UserService userService = new UserServiceImpl();
		//2切面类
		final MyAspect myAspect = new MyAspect();
		/* 3 代理类:将目标类(切入点)和 切面类(通知) 结合 --> 切面
		 * 	Proxy.newProxyInstance
		 * 		参数1:loader ,类加载器,动态代理类 运行时创建,任何类都需要类加载器将其加载到内存。
		 * 			一般情况:当前类.class.getClassLoader();
		 * 					目标类实例.getClass().get...
		 * 		参数2:Class[] interfaces 代理类需要实现的所有接口
		 * 			方式1:目标类实例.getClass().getInterfaces()  ;注意:只能获得自己接口,不能获得父元素接口
		 * 			方式2:new Class[]{UserService.class}   
		 * 			例如:jdbc 驱动  --> DriverManager  获得接口 Connection
		 * 		参数3:InvocationHandler  处理类,接口,必须进行实现类,一般采用匿名内部
		 * 			提供 invoke 方法,代理类的每一个方法执行时,都将调用一次invoke
		 * 				参数31:Object proxy :代理对象
		 * 				参数32:Method method : 代理对象当前执行的方法的描述对象(反射)
		 * 					执行方法名:method.getName()
		 * 					执行方法:method.invoke(对象,实际参数)
		 * 				参数33:Object[] args :方法实际参数
		 * 
		 */
		UserService proxService = (UserService)Proxy.newProxyInstance(
								MyBeanFactory.class.getClassLoader(), 
								userService.getClass().getInterfaces(), 
								new InvocationHandler() {	
									@Override
									public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
										//前执行
										myAspect.before();	
										//执行目标类的方法
										Object obj = method.invoke(userService, args);				
										//后执行
										myAspect.after();
										
										return obj;
									}
								});
		return proxService;
	}

}

 

今天的文章method.invoke()和invoke()简单理解分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/8561.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注