调试动态代理创建会改变调用处理程序状态

Debugging dynamic proxy creation mutates invocationhandler state

给定以下具有调用处理程序的动态 java 代理,其内部状态在调用期间发生变化:

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

public class Main {
    public static void main(String[] args) {
        Test test = (Test) Proxy.newProxyInstance(
                Test.class.getClassLoader(),
                new Class[] { Test.class },
                new MyInvocationHandler(true));
        test.doWork();
        test.doWork();
    }

    public interface Test {
        void doWork();
    }

    public static class MyInvocationHandler implements InvocationHandler {
        private boolean flag;
        public MyInvocationHandler(boolean flag) {
            this.flag = flag;
        }
        @Override
        public Object invoke(Object o, Method method, Object[] objects) throws Throwable {
            if ("doWork".equals(method.getName())) {
                System.out.println("Flag is " + flag);
            }
            if (flag) {
                flag = false;
                // Do somemthing
            }
            return null;
        }
    }
}

我希望这会将以下内容写入标准输出:

Flag is true

Flag is false

但是一步步调试时,输出:

Flag is false

Flag is false

我正在使用 Java 11.0.5 和 IntelliJ IDEA 进行调试。

有人知道这里发生了什么吗?

'toString()' object view 选项已知会在调试期间引起副作用,因为它将调用在正常应用程序执行期间未调用的方法。如果你的应用状态依赖于这些方法,你应该禁用相应的选项(File | Settings | Build, Execution, Deployment | Debugger | Data Views | Java: 启用 'toString()' 对象视图):