文章目录
- 一、通过 MetaClass#invokeMethod 方法调用类其它方法
- 二、完整代码示例
一、通过 MetaClass#invokeMethod 方法调用类其它方法
注意在 invokeMethod 方法中 , 不能调用 invokeMethod 方法 , 这样调用肯定会出现无限循环递归 , 导致栈溢出 ;
此处只能通过调用 MetaClass#invokeMethod 方法 , 调用相关函数 ;
通过元类对象的 invokeMethod 方法 , 不会导致栈溢出 ;
获取该 Groovy 类的 metaClass , 然后调用 metaClass 的 invokeMethod 方法 , 传入调用对象 , 调用方法 , 方法参数 , 即可调用相关方法 ;
代码语言:javascript复制 // 检查该类中是否定义 name 方法 , 参数是 args
def hasMethod = metaClass.invokeMethod(this, "respondsTo", name, args)
传入了的方法名 , 如果存在 , 则直接通过 metaClass.invokeMethod 调用该方法 ;
代码语言:javascript复制 // 如果定义了该方法 , 则执行该方法
if (hasMethod) {
metaClass.invokeMethod(this, name, args)
}
二、完整代码示例
完整代码示例 :
代码语言:javascript复制class Student implements GroovyInterceptable{
def name;
def hello() {
System.out.println "Hello ${name}"
}
@Override
Object invokeMethod(String name, Object args) {
System.out.println "invokeMethod : $name"
/*
注意在 invokeMethod 方法中 , 不能调用 invokeMethod 方法
肯定会出现递归调用 , 导致栈溢出
只能通过调用 MetaClass#invokeMethod 方法 , 调用相关函数
*/
// 检查该类中是否定义 name 方法 , 参数是 args
def hasMethod = metaClass.invokeMethod(this, "respondsTo", name, args)
/*
注意这里区分 Student 中的 invokeMethod 方法 与
MetaClass 中的 invokeMethod 方法
*/
// 如果定义了该方法 , 则执行该方法
if (hasMethod) {
metaClass.invokeMethod(this, name, args)
}
}
}
def student = new Student(name: "Tom")
// 直接调用 hello 方法
student.hello()
// 调用不存在的方法 , 也会触发 invokeMethod 方法
student.hello1()
// 通过 GroovyObject#invokeMethod 调用 hello 方法
// 第二个参数是函数参数 , 如果为 void 则传入 null
//student.invokeMethod("hello", null)
// 获取 元方法
//MetaMethod metaMethod = student.getMetaClass().getMetaMethod("hello", null)
// 执行元方法
//metaMethod.invoke(student, null)
执行结果 :
代码语言:javascript复制invokeMethod : hello
Hello Tom
invokeMethod : hello1