これを開始する方法がわかりません。私はばかばかしいNullPointerException
があるべきではない場所にある。状況は異常のように見えるので、私は答えからあまり期待していませんが、質問と答え(私が最終的に見つけたら)は教育目的に役立つかもしれません。そうでない場合は、おそらく質問を削除します。最初readonly
変数で最終フィールドにアクセスすると奇妙な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: }
決勝ではなかったので、それは危険な出版効果かもしれない私が、今は何のアイデアを持っていません。これらの変数にはコード内のリフレクトトリックはありませんが、このクラスの子孫のいくつかのメソッドは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
あなたが投稿したコードに何かがないと仮定して、私は通常、そのようなNullPointerExceptionが発生したときに、自動的にunboxingするnull値を探します。 – EasterBunnyBugSmasher
_ **しかし、このクラスの子孫のいくつかのメソッドはaspectj **でプロキシされています_それはどこかにあります。それなしでは伝えられない。 –
あなたは逆コンパイルされたaspectクラスを見てみることができます(私はhttps://eclipse.org/aspectj/doc/released/pdguide/ltwdump.html#ltwdump-あなたがltwを使うと仮定します)。実行時プロキシは、 stacktraceとまた最終的な方法について文句を言う) – zapl