- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我的应用程序在 Assets 文件夹中有一个 SQLite 数据库。当用户启动我的应用程序时,会创建数据库和表。
这适用于许多设备(Nexus One、Htc Magic、SGS、X10……甚至 Htc Desire HD v2.2)。我的应用程序适用于所有版本的 Android(在我的设备(1.6、2.2、2.2.1 Htc Magic)和模拟器(v1,5 到 v2.3)上测试。
我刚刚遇到 HTC DESIRE HD v2.2.1 1.72.405.3 的问题。
日志:
android.database.sqlite.SQLiteException: no such table: LISTE: , while compiling: select _id from LISTE at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2833) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2854) at android.app.ActivityThread.access$2300(ActivityThread.java:136) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2179) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:143) at android.app.ActivityThread.main(ActivityThread.java:5068) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:521) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) at dalvik.system.NativeStart.main(Native Method) Caused by: android.database.sqlite.SQLiteException: no such table: LISTE: , while compiling: select _id from LISTE at android.database.sqlite.SQLiteCompiledSql.native_compile(Native Method) at android.database.sqlite.SQLiteCompiledSql.compile(SQLiteCompiledSql.java:91) at android.database.sqlite.SQLiteCompiledSql.(SQLiteCompiledSql.java:64) at android.database.sqlite.SQLiteProgram.(SQLiteProgram.java:80) at android.database.sqlite.SQLiteQuery.(SQLiteQuery.java:46) at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:53) at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1417) at android.database.sqlite.SQLiteDatabase.rawQuery(SQLiteDatabase.java:1387) ... 11 more
我的应用程序创建了数据库,但它没有复制 data\data\packagename\databases\mydatabase
中 Assets 文件夹文件的表。
我的代码:
public void createDataBase() throws IOException{
boolean dbExist = checkDataBase();
if(dbExist){
//do nothing - database already exist
}else{
//By calling this method and empty database will be created into the default system path
//of your application so we are gonna be able to overwrite that database with our database.
this.getReadableDatabase();
try {
copyDataBase();
} catch (IOException e) {
throw new Error("Error copying database");
}
}
}
private void copyDataBase() throws IOException{
//Open your local db as the input stream
InputStream myInput = myContext.getAssets().open(DB_NAME);
// Path to the just created empty db
String outFileName = DB_PATH + DB_NAME;
//Open the empty db as the output stream
OutputStream myOutput = new FileOutputStream(outFileName);
//transfer bytes from the inputfile to the outputfile
byte[] buffer = new byte[1024];
int length;
while ((length = myInput.read(buffer))!= -1){
if (length > 0){
myOutput.write(buffer, 0, length);
} }
//Close the streams
myOutput.flush();
myOutput.close();
myInput.close();
}
我认为 copydatabase
函数有问题,但我没有看到。
此代码适用于所有设备,HTC DESIRE HD v2.2.1 1.72.405.3 除外。
对于上述给定版本的 HTC Desire,这里可能存在什么问题?如何补救?
最佳答案
这是一个猜测,暗示在 Desire HD 的 Android 版本中存在一个“错误”,所以我可能会疯狂地出局。
我想知道那个版本的 Android 是否没有在它应该做的地方创建数据库。您假设 DB_PATH 是\data\data\packagename\databases\,因为它通常是,但如果不是呢?结果将是以下...
this.getReadableDatabase()
将在\some\incorrect\path\mydatabase 处创建一个空数据库新
文件输出流(输出文件名)
简单地创建一个新的空二进制文件文件,因为上面没有创建位于您期望的位置的数据库。getReadableDatabase()
或 getWriteableDatabase()
请求访问数据库,但这两者都只会打开空数据库在步骤 1 中创建。简而言之,复制过程可能工作正常,但正在操作的数据库是空的,并且与您期望的位置不同。
只是一个想法(多年来我看到类似的事情发生)。
关于android - 特定版本的 HTC DESIRE HD 在 SQLite 中缺少表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4662941/
我知道您可以为 Zune 编写应用程序,但是 Zune HD 怎么样? 最佳答案 答案: http://coolthingoftheday.blogspot.com/2009/09/xna-game-
我期待使用 grep 命令从 top 命令中提取磁盘内存使用情况,并将其保存到 bash 解释器可用的变量中。 最佳答案 ...我假设您未能从 top 的输出中 grep 那些部分而不理解为什么...
我读到了 point/pixels苹果文档中的一些内容,但我仍然不完全清楚。我试图完成的是将工具栏放置在触摸 TextView 时出现的键盘上方。在 IOS4 之前,它的工作方式是将工具栏放置在位置
我使用 Locale.getDefault.getDisplayLanauge() 来获取语言代码,但我得到的是“hd”。我不知道那是什么。我想应该是“en”。 谁能告诉我为什么它默认为“高清”,它是
编辑:按照第一个答案,我更深入地研究了stackoverflow,并将问题重新表述为°如何仅使用高清文件?”并发现:How do I stop Cocos2D from requiring stand
根据Delphi XE2的发行说明。 FireMonkey可以创建高清应用程序。 HD 代表高清晰度。为什么是高清? VCL应用程序不能像FireMonkey一样创建高清应用程序吗? 最佳答案 这是d
我想从YouTube的网址下载视频。我使用pytube,但它仅下载低分辨率视频或高分辨率而没有音频。如何在python中从youtube下载带有音频的高分辨率视频?谢谢 最佳答案 我怀疑您是在谈论这个
我最近一直在Hive的PHD VM上运行一些基本脚本。 下面的大多数内容在我之前使用的apache发行版上都可以正常工作,但是现在在PHD版本上,where,sum,group by或基本上任何操作都
我正在尝试运行一种曾经可以运行但无法成功运行的最简单的OpenGL 3.3程序。程序始终以负整数返回。 这就是我遇到这种情况的方法。除了遵循本指南LearnOpenGL - Creating a wi
我已经构建并部署了由 zune hd 的新项目模板创建的应用程序。问题是每当应用程序退出时,Zune 就会重新启动。从 PC 远程调试或直接从设备运行时会发生这种情况。它发生在 Debug模式和 Re
在我的ryzen 3 2200g上的Vega 8 iGPU上,此着色器似乎可以正常编译,但同一片段着色器在intel hd 4000图形上无法编译。确实存在着色器错误或我做错了吗?我还采取了一些步骤,
我正在用 cocos2d 制作游戏。我正在检查 Sprite 的级别并相应地更新纹理。现在开始时图像是高清的。现在当游戏开始并且我开始移动 Sprite 时,高清图像被普通图像取代。我正在检查用这段代
我正在开发一个 C++ 应用程序(在 Linux 机器上运行),它非常注重读取日志文件并将派生结果写入磁盘。我想知道哪些是优化此类应用程序的最佳实践: 哪些操作系统调整可以提高性能? 哪些编程模式可以
无法在“Macintosh HD”上安装 Xcode,因为需要 macOS 10.12.6 或更高版本。我的 macitosh 版本是 10.12,但是当我搜索更新时它询问没有可用的更新 最佳答案 需
我正在尝试编写我的第一个 firemonkey - HD 应用程序 创建 firemonkey - HD 应用程序 在表单上放置一个 TLabel 并更改其名称。 选择 TLabel 在下拉菜单中选择
将文件存储在本地存储中与存储在 Azure 虚拟机 HD(如 d:\或 e:)上有区别吗?据我了解,它们是相同的。 谢谢 最佳答案 不知道为什么要将本地存储与 Azure 虚拟机的 HD 进行比较,因
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我的应用程序通过在我的请求的 hd 参数中指定 abc.com,将 Oauth2 的登录限制为特定域,例如 abc.com。 Restrict Login Email with Google OAut
我有一个 Android 应用程序可以创建本地 HTML 文件,然后在浏览器中将其显示给用户。我遇到过 BrowserActivity 无法在不同设备上运行的问题,具体取决于安装的浏览器。我当前的代码
我有一个可在第一代 iPad 上运行的应用程序。这是一款使用cocos2d框架制作的游戏。 第一台 iPad 确实有 256mb 内存,并且使用仪器(内存监控工具)我能够确定该应用程序在设备上的大约
我是一名优秀的程序员,十分优秀!