在典型NPE的堆栈跟踪中,您将获得它所发生的行号.假设System.out.println(c1.returnChain().returnChain().returnChain().returnChain());在第144行(只是随机选取)你的NPE堆栈跟踪应该类似于:
java.lang.NullPointerException
at your.package.Chain(Chain.java:144)
因此,如果您将链调用放在多行上,它应该显示异常的位置.
我写了这个小例子:
package bla;
public class Something {
public static int count = 0;
public Something get() {
if(count == 2) {
return null;
}
++count;
return new Something();
}
public static void main(String[] args){
Something something = new Something();
Something test = something.get()
.get()
.get()
.get() // Should throw NPE
.get()
.get();
}
}
它给了我NPE说:在bla.Something.main(Something.java:18) – 确切地说NPE在链中发生的地方.
屏幕截图……