我正在完成此操作,但有些回滚很开心,所以当我尝试使用try-catch在文本文件中写入时,它给了我这样的错误:
Exception in thread "main" java.lang.NullPointerException
指向这一行:
output.format("%-10s%-20s%-20s%-20s%-20s%-20s%-20s%-20s%n", ....
我读过这可能发生,因为引用的对象是null
或其他东西。但在输出行之前,我尝试使用system.out.println()
输出所有值,并且没有问题。
有解决方法吗?
try {
record.setIncome(input.nextDouble());
record.setAtv(atv_sum);
record.setSumAtv(atv_sum+45.00);
DecimalFormat df = new DecimalFormat("#.###");
double soc_apd=(((record.getIncome()-record.getSumAtv())/simt)*soc_proc);
double iedz=((((record.getIncome()-record.getSumAtv()-soc_apd))/simt)*iedz_proc);
df.format(iedz);
double netto =record.getIncome()-(iedz+soc_apd);
if((record.getIncome()>=min_alga)){
output.format("%-10s%-20s%-20s%-20s%-20s%-20s%-20s%-20s%n",
year_n,
months[month_n],
df.format(record.getIncome()),
df.format(record.getAtv()),
df.format(record.getSumAtv()),
df.format(iedz),
df.format(soc_apd),
df.format(netto));
}else{
String error_1 = "Kļūda ! Alga ievadÄ«ta zem 0 vai minimÄ?lÄ?s algas "+min_alga+" LS";
System.err.println(error_1);
input.nextLine();
}
}
catch ( FormatterClosedException formatterClosedException ){
System.err.println(error_2);
return;
}
catch (NoSuchElementException elementException){
System.err.println(error_3);
input.nextLine();
}
我发现哪条记录存在问题。输出是这样的:
所以df.format(record.getIncome())
可以解决问题
2013
45.0
Exception in thread "main" java.lang.NullPointerException
at course.CreateTextFile.addRecords(CreateTextFile.java:163)
at course.calc.CreateTextFileTest(calc.java:16)
at course.calc.main(calc.java:33)
321.468
165.55
1062.982
1550.0
答案 0 :(得分:2)
可能是因为output
本身为空?如果您正在打印的变量之一为null,则不会获得nullpointer,因为它只会打印文本“null”。但对于您使用df
格式化的参数,您会这样做。所以那些可能是候选人。这就像调试代码并检查什么是null一样简单。
顺便说一句,我甚至没有看到声明的输出,但很可能它应该是一个字符串。在这种情况下,输出为空无关紧要,因为format
是静态方法。您应该以静态方式访问方法格式,即String.format
所以,总结一下:
output
是什么。output
是字符串,请以静态方式访问format
。答案 1 :(得分:0)
您需要从以下行调试并验证哪个对象为null
...可能性是......例如months, output
等
output.format("%-10s%-20s%-20s%-20s%-20s%-20s%-20s%-20s%n",
year_n,
months[month_n],
df.format(record.getIncome()),
df.format(record.getAtv()),
df.format(record.getSumAtv()),
df.format(iedz),
df.format(soc_apd),
df.format(netto));
}