2016-01-27 11 views
36

LocalDateTime.now()ThreeTenABPと返されているモトローラデバイスでは、私は非常に奇妙な動作をしています。モトローラのデバイス:ThreeTenで日付を解析するときのorg.threeten.bp.DateTimeException

コードは以下の通りです:のみ、これらのデバイス(6.0を実行している唯一の3モトローラ・デバイス)上

@Override 
protected void onResume() { 
    super.onResume(); 
    if (!TextUtils.isEmpty(timeout)) { 
     LocalDateTime savedTime = LocalDateTime.parse(timeout, DateTimeFormatter.ISO_DATE_TIME); 
     if (LocalDateTime.now().isAfter(savedTime)) { 
      refresh() 
     } 
    } 
} 

@Override 
protected void onPause() { 
    super.onPause(); 
    LocalDateTime currentTime = LocalDateTime.now().plus(Duration.ofMinutes(10)); 
    timeout = currentTime.format(DateTimeFormatter.ISO_DATE_TIME); 
} 

私はこのクラッシュを持っている:

Fatal Exception: java.lang.RuntimeException: Unable to resume activity {com.myapp/com.myapp.MainActivity}: org.threeten.bp.format.DateTimeParseException: Text '0000-00-00T00:00:00.8' could not be parsed: Invalid value for MonthOfYear (valid values 1 - 12): 0 
     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3121) 
     at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3152) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1398) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:148) 
     at android.app.ActivityThread.main(ActivityThread.java:5443) 
     at java.lang.reflect.Method.invoke(Method.java) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:728) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
Caused by org.threeten.bp.format.DateTimeParseException: Text '0000-00-00T00:00:00.8' could not be parsed: Invalid value for MonthOfYear (valid values 1 - 12): 0 
     at org.threeten.bp.format.DateTimeFormatter.createError(DateTimeFormatter.java:1559) 
     at org.threeten.bp.format.DateTimeFormatter.parse(DateTimeFormatter.java:1496) 
     at org.threeten.bp.LocalDateTime.parse(LocalDateTime.java:444) 
     at com.myapp.MainActivity.onResume(MainActivity.java:273) 
     at android.app.Activity.performResume(Activity.java:6344) 
     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3110) 
     at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3152) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1398) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:148) 
     at android.app.ActivityThread.main(ActivityThread.java:5443) 
     at java.lang.reflect.Method.invoke(Method.java) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:728) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
Caused by org.threeten.bp.DateTimeException: Invalid value for MonthOfYear (valid values 1 - 12): 0 
     at org.threeten.bp.temporal.ValueRange.checkValidValue(ValueRange.java:278) 
     at org.threeten.bp.temporal.ChronoField.checkValidValue(ChronoField.java:557) 
     at org.threeten.bp.LocalDate.of(LocalDate.java:237) 
     at org.threeten.bp.chrono.IsoChronology.resolveDate(IsoChronology.java:452) 
     at org.threeten.bp.format.DateTimeBuilder.mergeDate(DateTimeBuilder.java:297) 
     at org.threeten.bp.format.DateTimeBuilder.resolve(DateTimeBuilder.java:206) 
     at org.threeten.bp.format.DateTimeFormatter.parse(DateTimeFormatter.java:1491) 
     at org.threeten.bp.LocalDateTime.parse(LocalDateTime.java:444) 
     at com.myapp.MainActivity.onPostResume(MainActivity.java:273) 
     at android.app.Activity.performResume(Activity.java:6344) 
     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3110) 
     at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3152) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1398) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:148) 
     at android.app.ActivityThread.main(ActivityThread.java:5443) 
     at java.lang.reflect.Method.invoke(Method.java) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:728) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 

ライン273 :

LocalDateTime savedTime = LocalDateTime.parse(timeout, DateTimeFormatter.ISO_DATE_TIME); 

したがって、基本的にLocaleDateTime.now()が無効な日付時刻を返しており、解析が失敗します。

もう1つ興味深いのは、1月初めから発生したことだけです。誰でもその問題に直面したことがありますか?

+0

この[SO-質問]で説明したのと同じ問題を(以下http://stackoverflow.com/questions/34691990/weird-org-threeten-bp-datetimeexception-投げ捨てられました)、私の答えも見てください。 –

+0

あなたはライブラリを放棄しましたか?このような問題は非常に面倒です。 –

+0

@MenoHochschild何かの理由でモトローラとアンドロイド6の言及はありませんが、関連する質問に感謝します。 –

答えて

0

利用代わりたぶん

Calendar calendar = Calendar.getInstance(); 
calendar.add(Calendar.MINUTE,10); 
Date date = calendar.getTime(); 
関連する問題