爲什麼我的應用程序崩潰?它崩潰在fis.close();
線上。 這是一個AsyncTask
的doInBackground
方法。FileInputStream崩潰.close()NPE
String collected = null;
FileInputStream fis = null;
try {
fis = openFileInput(FILENAME);
byte[] dataArray = new byte[fis.available()];
while (fis.read(dataArray) != -1) {
collected = new String(dataArray);
}
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
try {
fis.close();
return collected;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return null;
}
-
12-10 14:12:47.431: E/AndroidRuntime(701): FATAL EXCEPTION: AsyncTask #1
12-10 14:12:47.431: E/AndroidRuntime(701): java.lang.RuntimeException: An error occured while executing doInBackground()
12-10 14:12:47.431: E/AndroidRuntime(701): at android.os.AsyncTask$3.done(AsyncTask.java:299)
12-10 14:12:47.431: E/AndroidRuntime(701): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
12-10 14:12:47.431: E/AndroidRuntime(701): at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
12-10 14:12:47.431: E/AndroidRuntime(701): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
12-10 14:12:47.431: E/AndroidRuntime(701): at java.util.concurrent.FutureTask.run(FutureTask.java:137)
12-10 14:12:47.431: E/AndroidRuntime(701): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
12-10 14:12:47.431: E/AndroidRuntime(701): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
12-10 14:12:47.431: E/AndroidRuntime(701): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
12-10 14:12:47.431: E/AndroidRuntime(701): at java.lang.Thread.run(Thread.java:856)
12-10 14:12:47.431: E/AndroidRuntime(701): Caused by: java.lang.NullPointerException
12-10 14:12:47.431: E/AndroidRuntime(701): at com.ollygrov.doughpro.CustomRecipe$loadDatas.doInBackground(CustomRecipe.java:471)
12-10 14:12:47.431: E/AndroidRuntime(701): at com.ollygrov.doughpro.CustomRecipe$loadDatas.doInBackground(CustomRecipe.java:1)
12-10 14:12:47.431: E/AndroidRuntime(701): at android.os.AsyncTask$2.call(AsyncTask.java:287)
12-10 14:12:47.431: E/AndroidRuntime(701): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
感謝您的快速回復,我以前使用FileOutputStream保存了一個文件,並且試圖回想那個保存的文件。兩者都是相同的字符串。難道這個文件最初從來沒有保存過嗎?在完成工作後,我將不得不深入研究這個問題,我會盡快回復您 – Ollygrov
只需看看您遇到的異常情況。 –
確定添加了一個空檢查器,它是一個空流。它爲什麼這樣做? FILENAME不爲空它是一個字符串,並且在保存方法中似乎創建了一個文件 – Ollygrov