Javaダイナミックエージェント中報java.lang.I llegalArgumentException不正パラメータ異常

4413 ワード

今日、動的エージェントを学習しています.デバッグ中に不正なパラメータの異常が発生しました.まず、異常を見てみましょう.
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);
        }
    }

}