调试动态代理创建会改变调用处理程序状态
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()' 对象视图):
给定以下具有调用处理程序的动态 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()' 对象视图):