gpt4 book ai didi

java - 访问最终字段时出现奇怪的 NullPointerException

转载 作者:搜寻专家 更新时间:2023-10-31 20:32:45 25 4
gpt4 key购买 nike

我不确定如何开始。我在不应该出现的地方出现了可笑的NullPointerException。我对答案的期望不高,因为情况看起来很反常,但问题和答案(如果我最终找到了)可能对教育有用。如果不是,我可能会删除问题。

Caused by: java.lang.NullPointerException
at com.ah.dao.hbase.Snapshotable.lock(Snapshotable.java:17)
at com.ah.pipeline.dump.DumpController.dump(DumpController.java:78)

07: public abstract class Snapshotable {
08: private final AtomicBoolean readonly = new AtomicBoolean(false);
09:
10: abstract public TableSuit getTableInfo();
11:
12: public boolean locked() {
13: return readonly.get();
14: }
15:
16: public final void lock() {
17: readonly.set(true); <-- happens here
18: }
19:
20: public final void release() {
21: readonly.set(false);
22: }
23: }

起初 readonly 变量不是最终的,所以我虽然它可能是一个不安全的发布效果,但现在我没有想法。在我们的代码中这些变量没有反射技巧,但是这个类后代的一些方法是用 aspectj 代理的。


更新 aop 详细信息

@Service
public class HDao extends Snapshotable {

@PerformanceMonitoring
public void save(PatchEvent patchEvent) {
if (locked()) {
throw new DumpException(tableName);
}

@Aspect
@Component
public class PMAdvice {

@Around(value = "@annotation(performanceMonitoring)", argNames = "jp, p")
public Object saveEvent(ProceedingJoinPoint jp, PerformanceMonitoring p) throws Throwable {
// basic stuff

最佳答案

我可以用一个小程序重现它。这个问题确实与 AOP 有关。在调试的帮助下,我发现 final方法不适用于 AspectJ 代理。

事实证明,AspectJ 中的代理是通过运行时子类化完成的。因此它创建了一个包装器子类,它将所有方法委托(delegate)给代理对象。它适用于非 final方法。

简化示例:

class WrapperProxy extends MyClass {
private MyClass delegate = new MyClass();

@Override
public void run() {
delegate.run();
}
}

这种技术在 final 方法上有一个问题,因为它们不能在子类中被覆盖。 AspectJ 以一种奇怪的方式处理它:它创建另一个 MyClass 的委托(delegate)实例并将所有 final方法调用重定向到它。这个委托(delegate)甚至没有初始化,在我的例子中它有 null final 字段。

为了解决我的特殊问题,我刚刚从方法中删除了一个 final 关键字。

关于java - 访问最终字段时出现奇怪的 NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37393885/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com