我有一个奇怪的问题,第一次启动应用程序时,它运行良好,第二次崩溃,第三次工作,第四次崩溃等等。 这是logcat:
E/AndroidRuntime(18039): FATAL EXCEPTION: main
E/AndroidRuntime(18039): java.lang.RuntimeException: Unable to start activity Co
mponentInfo{omar.quran1/omar.quran1.Quran}: java.lang.NullPointerException
E/AndroidRuntime(18039): at android.app.ActivityThread.performLaunchActiv
ity(ActivityThread.java:1768)
E/AndroidRuntime(18039): at android.app.ActivityThread.handleLaunchActivi
ty(ActivityThread.java:1784)
E/AndroidRuntime(18039): at android.app.ActivityThread.access$1500(Activi
tyThread.java:123)
E/AndroidRuntime(18039): at android.app.ActivityThread$H.handleMessage(Ac
tivityThread.java:939)
E/AndroidRuntime(18039): at android.os.Handler.dispatchMessage(Handler.ja
va:99)
E/AndroidRuntime(18039): at android.os.Looper.loop(Looper.java:130)
E/AndroidRuntime(18039): at android.app.ActivityThread.main(ActivityThrea
d.java:3835)
E/AndroidRuntime(18039): at java.lang.reflect.Method.invokeNative(Native
Method)
E/AndroidRuntime(18039): at java.lang.reflect.Method.invoke(Method.java:5
07)
E/AndroidRuntime(18039): at com.android.internal.os.ZygoteInit$MethodAndA
rgsCaller.run(ZygoteInit.java:847)
E/AndroidRuntime(18039): at com.android.internal.os.ZygoteInit.main(Zygot
eInit.java:605)
E/AndroidRuntime(18039): at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime(18039): Caused by: java.lang.NullPointerException
E/AndroidRuntime(18039): at omar.quran1.Quran.getReaders(Quran.java:565)
E/AndroidRuntime(18039): at omar.quran1.Quran.onCreate(Quran.java:414)
E/AndroidRuntime(18039): at android.app.Instrumentation.callActivityOnCre
ate(Instrumentation.java:1047)
E/AndroidRuntime(18039): at android.app.ActivityThread.performLaunchActiv
ity(ActivityThread.java:1722)
E/AndroidRuntime(18039): ... 11 more
因此,当代码到达getReaders()时,它会崩溃,并且正好在这一行
int lengthtmp=f.listFiles().length;
这是功能:
public void getReaders()
{
File f = new File(SuraDatabase.Audio_PATH);
if(f!=null)
{
int lengthtmp=f.listFiles().length; //It crashes here - NullPointerException
if(lengthtmp==0||lengthtmp>10)
{
SoundFiles=false;
}
else
{
SoundFiles=true;
File[] readArrays=f.listFiles();
for(int i =0;i<lengthtmp;i++)
{
if(readArrays[i].isDirectory())
{
ReaderOptions.add(readArrays[i].getName());
}
}
}
}
}
有谁能告诉我为什么那条线会返回Null? 感谢。
答案 0 :(得分:0)
首先,由于您正在检查f是否为null,而是检查是否f.exists()
。因为如果那不存在,那么它就无法列出任何内容,因此它将为null,这将导致您的异常。
这不是你问题的答案,但试试看看会发生什么,并发布你的结果,这样我们就可以给你一个更好的答案。
我也猜测你是在第一次运行后以某种方式删除了这个目录,但这只是猜测而没有看到实际的代码。
答案 1 :(得分:0)
您可以尝试将变量“f”更改为更具描述性的内容。我遇到了android忽略1个字符的变量。
答案 2 :(得分:0)
listFiles可以返回null。尝试检查它是一个目录(File.isDirectory()),并且返回值不为null。