GSON を使用すると問題が発生します。
まず、アクティビティを切り替えるたびに、GSON を使用して SharedPreferences 内にオブジェクトを保存しようとしています。次に、アクティビティに戻ったらそのオブジェクトを再度取得して、そのページでキャプチャされたデータを再入力できるようにすることを計画しました。しかし、私の問題は、onPause メソッドでエラーが発生することです。このエラーはすでに 2 日間私を悩ませています。皆さんが助けてくれることを願っています。私は真剣にそれを必要としています。
これが私の onPause と onResume のコードです:
@Override
protected void onPause() {
super.onPause();
try {
SharedPreferences appSharedPrefs = PreferenceManager.getDefaultSharedPreferences(this.getApplicationContext());
Editor prefsEditor = appSharedPrefs.edit();
activityDataContainer = convertDataContainers(); //This just gets the data from the page
prefsEditor.putInt("objectLength", activityDataContainer.size());
Gson gson = new Gson();
for(int x = 0; x < activityDataContainer.size(); x++){
ConnectionObject temp = activityDataContainer.get(x);
String json = gson.toJson(temp);
prefsEditor.putString("connectionData"+x, json);
}
prefsEditor.commit();
Toast.makeText(this, "Object stored in SharedPreferences", Toast.LENGTH_SHORT).show();
} catch (Exception e) {
Toast.makeText(this, ""+e, Toast.LENGTH_LONG).show();
e.printStackTrace();
}
};
@Override
protected void onResume() {
super.onResume();
//===== Using SharedPreferences
SharedPreferences appSharedPrefs = PreferenceManager.getDefaultSharedPreferences(this.getApplicationContext());
if(appSharedPrefs.contains("objectLength")){
int length = appSharedPrefs.getInt("objectLength", 0);
activityDataContainer = new ArrayList<ConnectionObject>();
Gson gson = new Gson();
for(int x = 0; x < length; x++){
String json = appSharedPrefs.getString("connectionData"+x, "");
ConnectionObject object = gson.fromJson(json, ConnectionObject.class);
activityDataContainer.add(object);
}
revertDataContainers(activityDataContainer); //Repopulates the data
Toast.makeText(this, "Object retrieved in SharedPreferences", Toast.LENGTH_SHORT).show();
}
}
これが私が得るエラーログです:
05-10 02:14:47.822: E/AndroidRuntime(31718): 致命的な例外: メイン 05-10 02:14:47.822: E/AndroidRuntime(31718): java.lang.RuntimeException: アクティビティを一時停止できません {com.NelConsulting.FieldCaptureTool/com.MyClass}: java.lang.IllegalArgumentException: クラス android.database.sqlite .SQLiteDatabase は、mLock という名前の複数の JSON フィールドを宣言します 05-10 02:14:47.822: E/AndroidRuntime(31718): android.app.ActivityThread.performPauseActivity(ActivityThread.java:2354) で 05-10 02:14:47.822: E/AndroidRuntime (31718): android.app.ActivityThread.performPauseActivity (ActivityThread.java:2311) で 05-10 02:14:47.822: E/AndroidRuntime (31718): android.app.ActivityThread.handlePauseActivity (ActivityThread.java:2291) で 05-10 02:14:47.822: E/AndroidRuntime(31718): android.app.ActivityThread.access$1700(ActivityThread.java:117) で 05-10 02:14:47.822: E/AndroidRuntime(31718): android.app.ActivityThread$H.handleMessage(ActivityThread.java:938) で 05-10 02:14:47.822: E/AndroidRuntime(31718): android.os.Handler.dispatchMessage(Handler.java:99) で 05-10 02:14:47.822: E/AndroidRuntime(31718): android.os.Looper.loop(Looper.java:130) 05-10 02:14:47.822: E/AndroidRuntime(31718): android.app.ActivityThread.main(ActivityThread.java:3683) で 05-10 02:14:47.822: E/AndroidRuntime(31718): java.lang.reflect.Method.invokeNative(ネイティブ メソッド) で 05-10 02:14:47.822: E/AndroidRuntime(31718): java.lang.reflect.Method.invoke(Method.java:507) で 05-10 02:14:47.822: E/AndroidRuntime(31718): com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) で 05-10 02:14:47.822: E/AndroidRuntime (31718): com.android.internal.os.ZygoteInit.main (ZygoteInit.java:597) で 05-10 02:14:47.822: E/AndroidRuntime(31718): dalvik.system.NativeStart.main(ネイティブ メソッド) で 05-10 02:14:47.822: E/AndroidRuntime(31718): 原因: java.lang.IllegalArgumentException: クラス android.database.sqlite.SQLiteDatabase は、mLock という名前の複数の JSON フィールドを宣言します 05-10 02:14:47.822: E/AndroidRuntime (31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.getBoundFields (ReflectiveTypeAdapterFactory.java:122) で 05-10 02:14:47.822: E/AndroidRuntime (31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.create (ReflectiveTypeAdapterFactory.java:72) で 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.Gson.getAdapter(Gson.java:349) 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1 で。(ReflectiveTypeAdapterFactory.java:82) 05-10 02:14:47.822: E/AndroidRuntime (31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.createBoundField (ReflectiveTypeAdapterFactory.java:81) で 05-10 02:14:47.822: E/AndroidRuntime (31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.getBoundFields (ReflectiveTypeAdapterFactory.java:118) で 05-10 02:14:47.822: E/AndroidRuntime (31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.create (ReflectiveTypeAdapterFactory.java:72) で 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.Gson.getAdapter(Gson.java:349) 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.internal.bind.CollectionTypeAdapterFactory.create(CollectionTypeAdapterFactory.java:52) で 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.Gson.getAdapter(Gson.java:349) 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1 で。(ReflectiveTypeAdapterFactory.java:82) 05-10 02:14:47.822: E/AndroidRuntime (31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.createBoundField (ReflectiveTypeAdapterFactory.java:81) で 05-10 02:14:47.822: E/AndroidRuntime (31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.getBoundFields (ReflectiveTypeAdapterFactory.java:118) で 05-10 02:14:47.822: E/AndroidRuntime (31718): com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.create (ReflectiveTypeAdapterFactory.java:72) で 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.Gson.getAdapter(Gson.java:349) 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.internal.bind.TypeAdapterRuntimeTypeWrapper.write(TypeAdapterRuntimeTypeWrapper.java:55) で 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.internal.bind.CollectionTypeAdapterFactory$Adapter.write(CollectionTypeAdapterFactory.java:96) で 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.internal.bind.CollectionTypeAdapterFactory$Adapter.write(CollectionTypeAdapterFactory.java:60) で 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.Gson.toJson(Gson.java:582) 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.Gson.toJson(Gson.java:561) 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.Gson.toJson(Gson.java:516) 05-10 02:14:47.822: E/AndroidRuntime(31718): com.google.gson.Gson.toJson(Gson.java:496) 05-10 02:14:47.822: E/AndroidRuntime (31718): com.MyClass.onPause (ConnectionsActivity.java:804) で 05-10 02:14:47.822: E/AndroidRuntime(31718): android.app.Activity.performPause(Activity.java:3851) 05-10 02:14:47.822: E/AndroidRuntime(31718): android.app.Instrumentation.callActivityOnPause(Instrumentation.java:1191) で 05-10 02:14:47.822: E/AndroidRuntime(31718): android.app.ActivityThread.performPauseActivity(ActivityThread.java:2341) で
すべてのヘルプは大歓迎です。よろしくお願いします。
**編集 **ConnectionObject は、これらの値を格納する単純なオブジェクトです。
private boolean toggleButtonValue;
private int sdGenValue;
private int sdSpecValue;
private int sdCountValue;
private String sdLengthValue;
private int sdCondValue;
private int sdOwnValue;
private String sdDateValue;
private String mLtValue;
private String mLgValue;
private String mAcValue;
private int mPhotoValue;
private List<MeterObject> meterContainer;