2011-02-12 125 views
0

我有一个用户的崩溃报告,我不能在我的测试设备上自己重新创建相同的错误。奇怪的NullPointerException与日期对象

下面是相关代码:

 for(File f : sessionDirectory.listFiles()){ 
     Date lastModDate = new Date(f.lastModified()); 
    /*Line 53*/ Session ss = new Session(lastModDate.toLocaleString() , f.getName()) ; 
     sessionArrayList.add(ss) ; 
    } 

和这里的堆栈跟踪:

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.mydomain/com.mydomain.myActivity}: java.lang.NullPointerException 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2787) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2803) 
at android.app.ActivityThread.access$2300(ActivityThread.java:135) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2136) 
at android.os.Handler.dispatchMessage(Handler.java:99) 
at android.os.Looper.loop(Looper.java:144) 
at android.app.ActivityThread.main(ActivityThread.java:4937) 
at java.lang.reflect.Method.invokeNative(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:521) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
at dalvik.system.NativeStart.main(Native Method) 
Caused by: java.lang.NullPointerException 
at com.mydomain.myActivity.onCreate(myActivity.java:53) 
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1069) 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2751) 

回答

1

我见过这样的事情concerting日期时/从Java字符串表示(不是机器人)并且很长一段时间都不知道为什么。我不记得确切的细节,但它与转换方法不是线程安全有关,这很奇怪,因为(如果我没记错的话)它发生在一个静态jdk方法的调用中。

尝试当您将lastModDate.toLocaleString()拖入同步方法并使用DateFormat实例时仍然发生。

当我查找它时,在jdk中已经有一个反对这个bug的文件,但它被拒绝了。

(也许的toLocaleString使用连接到其所有线程之间共享当前地区的日期格式,并调用非线程的方法。)

然而这仅仅是猜测,但由于症状类似怪异,只是试试看。

1

堆栈跟踪说:

造成的: 显示java.lang.NullPointerException在 com.mydomain.myActivity.onCreate(myActivity.java:53)

什么是53行?

sessionDirectory可以nullsessionDirectory.listFiles()可以返回null - 也得到了用户崩溃报告提醒说:-)

+0

是否为null _f_可能? – extraneon 2011-02-12 13:06:52

+0

第53行是:`Session ss = new Session(lastModDate.toLocaleString(),f.getName());` – dirhem 2011-02-12 13:24:55