コードのどこが悪いのかを特定するのに苦労しているので、私は第二の目から助けをもらいたいと思っています。Eclipse IDEで、資産フォルダー( /assets/mmsi.txt)内のファイルから船のMMSIコードを読み取り、それぞれの場所にマップマーカーを追加
するGoogleマップアクティビティを実装しようとしています。クラスを使用してこのファイルから読み取ることはできますが、関数を使用して結果の行をdoubleに変換する際に問題が発生します。BufferedReader
String
Double.parseDouble
LogCatは、次の問題を検出します。
01-23 17:59:11.672: E/AndroidRuntime(18242): FATAL EXCEPTION: main
01-23 17:59:11.672: E/AndroidRuntime(18242): java.lang.RuntimeException: Unable to resume activity {com.aquamet.saramap/com.aquamet.saramap.MainActivity}: java.lang.NullPointerException
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3128)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3143)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2684)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.ActivityThread.access$2300(ActivityThread.java:125)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.os.Handler.dispatchMessage(Handler.java:99)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.os.Looper.loop(Looper.java:123)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.ActivityThread.main(ActivityThread.java:4627)
01-23 17:59:11.672: E/AndroidRuntime(18242): at java.lang.reflect.Method.invokeNative(Native Method)
01-23 17:59:11.672: E/AndroidRuntime(18242): at java.lang.reflect.Method.invoke(Method.java:521)
01-23 17:59:11.672: E/AndroidRuntime(18242): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:876)
01-23 17:59:11.672: E/AndroidRuntime(18242): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:634)
01-23 17:59:11.672: E/AndroidRuntime(18242): at dalvik.system.NativeStart.main(Native Method)
01-23 17:59:11.672: E/AndroidRuntime(18242): Caused by: java.lang.NullPointerException
01-23 17:59:11.672: E/AndroidRuntime(18242): at com.aquamet.saramap.MainActivity.getMMSI(MainActivity.java:173)
01-23 17:59:11.672: E/AndroidRuntime(18242): at com.aquamet.saramap.MainActivity.setupRegion(MainActivity.java:136)
01-23 17:59:11.672: E/AndroidRuntime(18242): at com.aquamet.saramap.MainActivity.onResume(MainActivity.java:82)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1149)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.Activity.performResume(Activity.java:3827)
01-23 17:59:11.672: E/AndroidRuntime(18242): at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3118)
01-23 17:59:11.672: E/AndroidRuntime(18242): ... 12 more
つまり、次のコードにNullPointerExceptionがあるようです。
private double[] getMMSI() throws IOException {
AssetManager am = this.getAssets();
double[] mmsi = null;
BufferedReader br = null;
try {
InputStream file_stream = am.open("mmsi.txt");
br = new BufferedReader(new InputStreamReader(file_stream));
} catch (FileNotFoundException e) {
e.printStackTrace();
}
String line;
for (int i=0; (line = br.readLine()) != null; i++) {
// Following line seems to be the problem (line 173).
mmsi[i] = Double.parseDouble(line);
}
try {
br.close();
} catch (IOException e) {
e.printStackTrace();
}
}
しかし、デバッグ中、変数line
は実際にはnullではありません!(画像のREPが足りません)
デバッグのスクリーンショット
別のSOユーザーも同様の問題を抱えていましたが、彼の変数は正しく初期化されていないようでした。 parseDoubleが私のコードでNullポインターをスローします[クローズ]