我正在使用Android模拟器进行测试,当它执行此功能时,它会强制关闭应用程序。但是,在我评论了以下语句之后,该功能已成功执行并生成了toast消息(E.g. String1|Sub1,Sub2,Sub3)
。当我取消注释第一个split()语句并尝试运行测试时,它会再次强制关闭应用程序。
public void readData()
{
try
{
FileInputStream fin = openFileInput("data.txt");
InputStreamReader isr = new InputStreamReader(fin);
BufferedReader br = new BufferedReader(isr);
String line;
do
{
line = br.readLine();
//String[] temp = line.split("|");
//String[] temp2 = temp[1].split(",");
//Vector<String> nameTemp = new Vector<String>(Arrays.asList(temp2));
//Team container = new Team(temp[0], nameTemp);
//grpContent.add(container);
invalidCharacterToast(line); //Toast message
}
while (line != null);
br.close();
isr.close();
}
catch (IOException e)
{
e.printStackTrace();
}
}
logcat的:
06-27 12:13:41.446: E/AndroidRuntime(289): FATAL EXCEPTION: main
06-27 12:13:41.446: E/AndroidRuntime(289): java.lang.NullPointerException
06-27 12:13:41.446: E/AndroidRuntime(289): at com.example.project.Start.readData(Start.java:196)
06-27 12:13:41.446: E/AndroidRuntime(289): at com.example.project.Start.onClick(Start.java:140)
06-27 12:13:41.446: E/AndroidRuntime(289): at android.view.View.performClick(View.java:2408)
06-27 12:13:41.446: E/AndroidRuntime(289): at android.view.View$PerformClick.run(View.java:8816)
06-27 12:13:41.446: E/AndroidRuntime(289): at android.os.Handler.handleCallback(Handler.java:587)
06-27 12:13:41.446: E/AndroidRuntime(289): at android.os.Handler.dispatchMessage(Handler.java:92)
06-27 12:13:41.446: E/AndroidRuntime(289): at android.os.Looper.loop(Looper.java:123)
06-27 12:13:41.446: E/AndroidRuntime(289): at android.app.ActivityThread.main(ActivityThread.java:4627)
06-27 12:13:41.446: E/AndroidRuntime(289): at java.lang.reflect.Method.invokeNative(Native Method)
06-27 12:13:41.446: E/AndroidRuntime(289): at java.lang.reflect.Method.invoke(Method.java:521)
06-27 12:13:41.446: E/AndroidRuntime(289): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
06-27 12:13:41.446: E/AndroidRuntime(289): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
06-27 12:13:41.446: E/AndroidRuntime(289): at dalvik.system.NativeStart.main(Native Method)
06-27 12:13:43.406: I/Process(289): Sending signal. PID: 289 SIG: 9
答案 0 :(得分:4)
这是一个do-while循环,因此在null检查之前执行br.readLine()
语句,因此可能会对split
执行第一个null
方法。
你应该重写它:
while ((line = br.readLine()) != null) {
// your code
}