• java动态语言MethodHandle(1)


    package vmrun;
    
    import java.lang.invoke.MethodHandle;
    import java.lang.invoke.MethodHandles;
    import java.lang.invoke.MethodHandles.Lookup;
    import java.lang.invoke.MethodType;
    
    public class MethodHandleTest {
    	
    	static class classA {
    		public void println(String s){
    			System.out.println("classA:"+s) ;
    		}
    	}
    	
    	public static void main(String [] args) throws Throwable{
    		Object object = System.currentTimeMillis()%2==0? System.out : new classA() ;
    		//无论 object是要那个实现类,下面的都能正确调用 到println方法
    		getPrintlnMH(object).invokeExact("lisj") ;
    	}
    	
    	private static MethodHandle getPrintlnMH(Object receiver) throws Throwable{
    		/**
    		 * MethodType表示“方法类型”,包含了方法的返回值(第一个参数)和具体的参数(第二个及其以后的参数)
    		 * 这里参考classA中的方法
    		 */
    		MethodType mt = MethodType.methodType(void.class, String.class) ;
    		/**
    		 *lookup:在指定的类中查找符合给定的方法名,有方法类型,并且符合调用权限的方法名柄。
    		 *这里调用的是一个虚方法,方法的第一个参数是隐式的,代表这个 方法的接收者,也就是this指向的对象,以前是放在参数列表中
    		 *传递的,现在提供了bindTo方法
    		 */
    		return MethodHandles.lookup().findVirtual(receiver.getClass(), "println", mt).bindTo(receiver) ;
    	}
    
    }
    

    MethodHandle与Reflection的不同:

    1.本质上讲两个都是在模拟方法的调用,但Reflection是模拟java代码层次的调用,而MethodHandle是模拟的字节码层次的,上面的例子中是模拟的invokevirtual指令。

    2.Reflection是重量级的,而MethodHandle是轻量级的。

    最重要的是,Reflection 只为java服务,而MethodHandle则可以服务于所有的运行在java虚拟机上的语言。

      

  • 相关阅读:
    sqlilab less19-less22
    sqlilab less11-less18
    逆向——序列号相关总结
    xctf攻防世界——crackme writeup
    ESP定律脱壳——NsPack3.x脱壳
    避免全局变量漫天飞
    C语言实现队列
    STM32中的C语言知识点
    超时事件时间戳
    STM32-电源控制、低功耗模式
  • 原文地址:https://www.cnblogs.com/chuiyuan/p/4781312.html
Copyright © 2020-2023  润新知