0

私はこれを修正することができましたが、なぜこれが壊れたのかについての良い説明を得ることができるかどうか疑問に思っています。

Androidアプリケーションのデータベースを使用して日付変換を処理するユーティリティ関数を作成しました。このコードは、2回目にアクセスされたときに失敗しました。

public class Util {

  private static final ParsePosition pos = new ParsePosition(0);

public static String isoDateFormat(Date d) {
      SimpleDateFormat databaseformat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
      return databaseformat.format(d);
  }

  public static Date isoToDate(String isodate) {
      SimpleDateFormat databaseformat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
      return databaseformat.parse(isodate, pos);
  } 
}

SimpleDateFormatのさまざまな機能がスレッドセーフではないことは理解していますが、(私が知る限り)私のプログラムは単一のスレッド内で実行されていました。私はアンドロイドに不慣れで、多分私は間違っています。ParsePositionをメソッドに移動して新しいものにすることで、これを修正できたことを私は知っています。スレッドセーフでなくても、それはほとんど一定ではありませんか?読み取り専用定数がスレッドを壊すのはなぜですか?

ありがとう!

編集:ここにスタックトレースがあります:

E/AndroidRuntime( 2753): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.mobile/com.example.mobile.ExampleSelector}: java.lang.NullPointerException
E/AndroidRuntime( 2753):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
E/AndroidRuntime( 2753):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
E/AndroidRuntime( 2753):    at android.app.ActivityThread.access$2300(ActivityThread.java:125)
E/AndroidRuntime( 2753):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
E/AndroidRuntime( 2753):    at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime( 2753):    at android.os.Looper.loop(Looper.java:123)
E/AndroidRuntime( 2753):    at android.app.ActivityThread.main(ActivityThread.java:4627)
E/AndroidRuntime( 2753):    at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 2753):    at java.lang.reflect.Method.invoke(Method.java:521)
E/AndroidRuntime( 2753):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
E/AndroidRuntime( 2753):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
E/AndroidRuntime( 2753):    at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime( 2753): Caused by: java.lang.NullPointerException
E/AndroidRuntime( 2753):    at Util.isoToDate(Util.java:34)
4

2 に答える 2

0

isoToDateで、isodateがnullでないことを確認してください。何かのようなもの:

public static Date isoToDate(String isodate) {
   if (isodate == null) {
      // Raise exception, or return default date
   }
}
于 2010-10-10T10:35:04.110 に答える
0

問題を引き起こしていたのはParsePositionであることが判明しました。毎回インスタンス化することで問題が解決しました。

于 2010-11-15T06:45:43.920 に答える