Javaダイナミックエージェント中報java.lang.I llegalArgumentException不正パラメータ異常
4413 ワード
今日、動的エージェントを学習しています.デバッグ中に不正なパラメータの異常が発生しました.まず、異常を見てみましょう.
その後、エージェント呼び出しハンドラを実際のオブジェクトメソッドを呼び出すときにinvokeメソッドの最初のパラメータをmethodと書き、実際のエージェントオブジェクトを書くべきだった.
正しい書き方は以下の通りです.
Exception in thread "main" java.lang.IllegalArgumentException: object is not an instance of declaring class
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at com.test.Application.WorkHandler.invoke(WorkHandler.java:24)
at com.sun.proxy.$Proxy0.time(Unknown Source)
at com.test.Application.Test.main(Test.java:18)
その後、エージェント呼び出しハンドラを実際のオブジェクトメソッドを呼び出すときにinvokeメソッドの最初のパラメータをmethodと書き、実際のエージェントオブジェクトを書くべきだった.
//
method.invoke(method, args);
正しい書き方は以下の通りです.
package com.test.Application;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
public class WorkHandler implements InvocationHandler{
private Object obj;
public WorkHandler(Object obj) {
this.obj = obj;
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println("before ...");
System.out.println(proxy.getClass().getName());
System.out.println(this.obj.getClass().getName());
if(method.getName().equals("work")) {
method.invoke(this.obj, args);
System.out.println("after ...");
return proxy;
} else {
System.out.println("after ...");
return method.invoke(this.obj, args);
}
}
}