Внешнее хранилище в Android

Я пытаюсь сохранить ArrayList во внешнем хранилище в приложении Android, и, похоже, каждый раз происходит сбой, но я не уверен, почему. Я следовал онлайн-учебникам по использованию внешнего хранилища, и я не вижу ничего отличного от кода, который у меня есть. Вот моя функция чтения:

public static ArrayList<MapRoute> readFile(Context context, String filename) {

        ObjectInputStream ois = null;
        ArrayList<MapRoute> result = null;

        if (!externalStorageAvailable || !externalStorageWritable) {
            Log.d("READ FAILED", Environment.getExternalStorageState());
            return null;
        }

        try {
            File file = new File(context.getExternalFilesDir(null), filename);
            FileInputStream fis = new FileInputStream(file);
            ois = new ObjectInputStream(fis);
            result = (ArrayList<MapRoute>)ois.readObject();
            ois.close();
        } catch (Exception e) {
            Log.d("FAILED", "READ FAILED");
        } finally {
            try {
                if (ois != null) {
                    ois.close();
                }
            } catch (IOException e) {
                Log.d("ENDREAD", "FAIL");
            }
        }

        return result;
    }

И писать:

public static boolean saveFile(Context context, ArrayList<MapRoute> routes, String filename) {

        if (!externalStorageAvailable && !externalStorageWritable) {
            Log.d("FAILED", "FAIL");
            return false;
        }

        File file = new File(context.getExternalFilesDir(null), filename);
        ObjectOutputStream oos = null;
        boolean success = false;

        try {
            OutputStream os = new FileOutputStream(file);
            oos = new ObjectOutputStream(os);
            oos.writeObject(routes);
            success = true;
        } catch (IOException e) {
            Log.d("OOS", "FAILED");
        } finally {
            try {
                if (oos != null) {
                    oos.close();
                }
            } catch (IOException e) {
                Log.d("OOS", "FAILED2");
            }
        }

        return success;
    }

В моем сообщении logcat выводится сообщение FAILED READ FAILED из блока try внутри функции readFile, и я не уверен, что это как-то связано со способом, которым я пытаюсь прочитать список массивов.

Любая помощь по этому вопросу будет принята с благодарностью.

РЕДАКТИРОВАТЬ: Вот трассировка стека

    03-13 22:20:33.690: W/System.err(25353): java.io.WriteAbortedException: Read an      exception; java.io.NotSerializableException: mark.es3.mapRoute.MapRoute
03-13 22:20:33.690: W/System.err(25353):    at java.io.ObjectInputStream.readNonPrimitiveContent(ObjectInputStream.java:933)
03-13 22:20:33.690: W/System.err(25353):    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:2262)
03-13 22:20:33.690: W/System.err(25353):    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:2217)
03-13 22:20:33.690: W/System.err(25353):    at java.util.ArrayList.readObject(ArrayList.java:665)
03-13 22:20:33.690: W/System.err(25353):    at java.lang.reflect.Method.invokeNative(Native Method)
03-13 22:20:33.690: W/System.err(25353):    at java.lang.reflect.Method.invoke(Method.java:507)
03-13 22:20:33.690: W/System.err(25353):    at java.io.ObjectInputStream.readObjectForClass(ObjectInputStream.java:1520)
03-13 22:20:33.690: W/System.err(25353):    at java.io.ObjectInputStream.readHierarchy(ObjectInputStream.java:1443)
03-13 22:20:33.695: W/System.err(25353):    at java.io.ObjectInputStream.readNewObject(ObjectInputStream.java:2112)
03-13 22:20:33.695: W/System.err(25353):    at java.io.ObjectInputStream.readNonPrimitiveContent(ObjectInputStream.java:916)
03-13 22:20:33.695: W/System.err(25353):    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:2262)
03-13 22:20:33.695: W/System.err(25353):    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:2217)
03-13 22:20:33.695: W/System.err(25353):    at mark.es3.activities.CreateSessionActivity$FavouriteRoutesTab.readFile(CreateSessionActivity.java:245)
03-13 22:20:33.695: W/System.err(25353):    at mark.es3.activities.CreateSessionActivity$FavouriteRoutesTab.onCreate(CreateSessionActivity.java:148)
03-13 22:20:33.695: W/System.err(25353):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-13 22:20:33.695: W/System.err(25353):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615)
03-13 22:20:33.695: W/System.err(25353):    at android.app.ActivityThread.startActivityNow(ActivityThread.java:1491)
03-13 22:20:33.695: W/System.err(25353):    at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:127)
03-13 22:20:33.700: W/System.err(25353):    at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:339)
03-13 22:20:33.700: W/System.err(25353):    at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:691)
03-13 22:20:33.700: W/System.err(25353):    at android.widget.TabHost.setCurrentTab(TabHost.java:341)
03-13 22:20:33.700: W/System.err(25353):    at android.widget.TabHost$2.onTabSelectionChanged(TabHost.java:140)
03-13 22:20:33.700: W/System.err(25353):    at android.widget.TabWidget$TabClickListener.onClick(TabWidget.java:456)
03-13 22:20:33.700: W/System.err(25353):    at android.view.View.performClick(View.java:2538)
03-13 22:20:33.700: W/System.err(25353):    at android.view.View$PerformClick.run(View.java:9152)
03-13 22:20:33.700: W/System.err(25353):    at android.os.Handler.handleCallback(Handler.java:587)
03-13 22:20:33.700: W/System.err(25353):    at android.os.Handler.dispatchMessage(Handler.java:92)
03-13 22:20:33.700: W/System.err(25353):    at android.os.Looper.loop(Looper.java:123)
03-13 22:20:33.720: W/System.err(25353):    at android.app.ActivityThread.main(ActivityThread.java:3691)
03-13 22:20:33.720: W/System.err(25353):    at java.lang.reflect.Method.invokeNative(Native Method)
03-13 22:20:33.720: W/System.err(25353):    at java.lang.reflect.Method.invoke(Method.java:507)
03-13 22:20:33.720: W/System.err(25353):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
03-13 22:20:33.720: W/System.err(25353):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
03-13 22:20:33.720: W/System.err(25353):    at dalvik.system.NativeStart.main(Native Method)
03-13 22:20:33.720: W/System.err(25353): Caused by: java.io.NotSerializableException: mark.es3.mapRoute.MapRoute
03-13 22:20:33.720: W/System.err(25353):    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1535)
03-13 22:20:33.720: W/System.err(25353):    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1847)
03-13 22:20:33.720: W/System.err(25353):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1689)
03-13 22:20:33.725: W/System.err(25353):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1653)
03-13 22:20:33.725: W/System.err(25353):    at java.util.ArrayList.writeObject(ArrayList.java:651)
03-13 22:20:33.725: W/System.err(25353):    at java.lang.reflect.Method.invokeNative(Native Method)
03-13 22:20:33.725: W/System.err(25353):    at java.lang.reflect.Method.invoke(Method.java:507)
03-13 22:20:33.725: W/System.err(25353):    at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1219)
03-13 22:20:33.725: W/System.err(25353):    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1575)
03-13 22:20:33.725: W/System.err(25353):    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1847)
03-13 22:20:33.725: W/System.err(25353):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1689)
03-13 22:20:33.725: W/System.err(25353):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1653)
03-13 22:20:33.725: W/System.err(25353):    at mark.es3.activities.CreateSessionActivity$FavouriteRoutesTab.saveFile(CreateSessionActivity.java:224)
03-13 22:20:33.725: W/System.err(25353):    at mark.es3.activities.CreateSessionActivity$FavouriteRoutesTab.saveRoute(CreateSessionActivity.java:207)
03-13 22:20:33.730: W/System.err(25353):    at mark.es3.activities.PlotRouteActivity.onHandleActionBarItemClick(PlotRouteActivity.java:94)
03-13 22:20:33.730: W/System.err(25353):    at greendroid.app.GDMapActivity$1.onActionBarItemClicked(GDMapActivity.java:247)
03-13 22:20:33.730: W/System.err(25353):    at greendroid.widget.ActionBar$1.onClick(ActionBar.java:396)
03-13 22:20:33.730: W/System.err(25353):    ... 11 more

Мой класс MapRoute реализует Serializable, поэтому я не уверен, что это значит.

1 ответ

Кажется твой MapRoute объект не сериализуем, поэтому вы не можете записать его в ObjectOutputStream, Возможные решения:

  • делать MapRoute и все классы, используемые в нем, реализуют Serializable
  • выполнить сериализацию / десериализацию "вручную".
Другие вопросы по тегам