我似乎搞不懂为什么这不管用。plow是我在另一个类文件中创建的构造函数,但我希望能够分配它,以便我以后可以通过为构造函数使用数组来更改犁的数量。
static int PLOWS=4
public static final String PLOW_DATA = "PlowData.txt";
public static void getPlowData(){
Plow[] plows = new Plow[PLOWS];
Scanner fileIn = null;
int a = 0;
int plowID;
String driver;
System.out.println("Reading Files....");
try
{
fileIn = new Scanner(new FileInputStream(PLOW_DATA));
System.out.println("File Found!");
}
catch (FileNotFoundException e)
{
System.out.println("Error: file '" + PLOW_DATA + "' not found.");
}
while (fileIn.hasNext())
{
//System.out.println("Writing...");
try{
plowID = fileIn.nextInt(); //reading plow ID
System.out.print(plowID+"\t");
plows[a].setPlowID(plowID);
}
catch (java.util.InputMismatchException e){
driver = fileIn.nextLine(); //reading Driver
System.out.println(driver);
plows[a].setDriver(driver);
}
a++;
}
fileIn.close();
System.out.println("Done!");
}当我运行它时,我会得到这个错误
10 Exception in thread "main" java.lang.NullPointerException
at um.csc276.JavaHomework4.HW4_1.getPlowData(HW4_1.java:63)
at um.csc276.JavaHomework4.HW4_1.main(HW4_1.java:149)发布于 2015-02-18 03:19:31
在这方面:
Plow[] plows = new Plow[PLOWS];您正在实例一个新的Plow对象数组。但是此时,数组将初始化为PLOWS项,但其中的所有项都将是null。每个项目都需要自己初始化。
所以当你到达这部分时:
plows[a].setPlowID(plowID); plows[a]为null,因此是运行时异常。
一个可能的解决方案,将在while块中,在try之前添加:
if (plows[a] == null) plows[a] = new Plow();编辑:正如@StenSoft所指出的,NPE的另一个原因是,如果while循环(以及稍后的close()调用)尝试使用FileInputStream;如果文件不存在,您只需捕获异常而不恢复(或中断),然后继续处理:流将为null,您将得到另一个NullPointerException。将while循环移到try catch中,那么放置close()调用的最佳位置是在finally中。
https://stackoverflow.com/questions/28575324
复制相似问题