Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/212.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android中的外部存储_Android_Io_Storage_External_Logcat - Fatal编程技术网

Android中的外部存储

Android中的外部存储,android,io,storage,external,logcat,Android,Io,Storage,External,Logcat,我试图将ArrayList保存到Android应用程序的外部存储中,但每次都失败了,但我不知道为什么。我已经学习了有关使用外部存储的在线教程,我看不到与我的代码有什么不同。这是我的阅读功能: public static ArrayList<MapRoute> readFile(Context context, String filename) { ObjectInputStream ois = null; ArrayList<MapRoute&

我试图将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;
    }

我的MapRoute类实现了Serializable,所以我不确定这意味着什么。

您的
MapRoute
对象似乎不可序列化,因此您无法将其写入
ObjectOutputStream
中。可能的解决办法:

  • 使
    MapRoute
    和其中使用的所有类实现可序列化
  • 手动执行序列化/非序列化

您的
MapRoute
对象似乎不可序列化,因此无法将其写入
ObjectOutputStream
。可能的解决办法:

  • 使
    MapRoute
    和其中使用的所有类实现可序列化
  • 手动执行序列化/非序列化

在清单中设置了所有权限?是否创建了您的文件?是的,我在manifest@Tim文件正在创建中,我可以使用android设备上的文件目录在包含“失败,读取失败”的catch块中浏览该文件添加e.printStackTrace();并在抛出异常时发布日志cat中显示的堆栈跟踪。清单中设置了privs all?文件是否已创建?是的,我的manifest@Tim文件正在创建中,我可以使用android设备上的文件目录在包含“失败,读取失败”的catch块中浏览该文件添加e.printStackTrace(); 并在抛出异常时发布日志cat中显示的堆栈跟踪。
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;
    }
    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