2

我正在尝试将现成的 sqlite v3 数据库从我的资产文件夹复制到我的应用程序的 /databases 文件夹中。但我得到一个 java 运行时异常。

private const string DB_PATH = "/data/com.MyApp/databases/dbname";

        public SQLiteDatabase GetDataBase()
        {
            SQLiteDatabase db = null;

            try
            {
                db = SQLiteDatabase.OpenDatabase(DB_PATH, null, SQLiteDatabase.OPEN_READONLY);
            }
            catch
            {
                this.GetReadableDatabase();
                InputStream inStream = _appContext.GetAssets().Open("HadithCompanion.bukhari");
                Helper.CreateFileFromInputStream(inStream, new File(DB_PATH));
                db = SQLiteDatabase.OpenDatabase(DB_PATH, null, SQLiteDatabase.OPEN_READONLY);
            }

            return db;
        }


        public static void CreateFileFromInputStream(InputStream inStream, File destination)
        {
            try
            {
                OutputStream outStream = new FileOutputStream(destination); // THIS CAUSES THE FAILURE
                CopyFile(inStream, outStream);
            }
            catch (Exception ex)
            {
                Log.E("OutputStream", ex.Message);
            }
        }

异常没有被捕获。文件“/data/com.MyApp/databases/dbname”尚不存在,我通过阅读文档假设它将在实例化 FileOutputStream 时创建。

我正在使用 C# 和 dot42 并在使用 JellyBean 4.2 的真实设备上进行测试

4

0 回答 0