1

我已经测试我的应用程序一段时间了,没有任何问题。但是,今天我在 myTouch 4G 上收到了来自 T-Mobile 的系统更新。我的应用程序使用 SQLCipher 现在在打开时崩溃并出现以下错误:

01-23 20:43:37.200 E/AndroidRuntime(5534): FATAL EXCEPTION: main
01-23 20:43:37.200 E/AndroidRuntime(5534): java.lang.UnsatisfiedLinkError: Cannot load library: reloc_library[1312]:  1235 cannot locate 'ucol_strcollIter_4_2'...
01-23 20:43:37.200 E/AndroidRuntime(5534): 
01-23 20:43:37.200 E/AndroidRuntime(5534):  at java.lang.Runtime.load(Runtime.java:394)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at java.lang.System.load(System.java:534)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at info.guardianproject.database.sqlcipher.SQLiteDatabase.loadLibs(SQLiteDatabase.java:123)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.app.myapp.datamanagement.DatabaseManager.open(DatabaseManager.java:62)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.app.myapp.datamanagement.DatabaseManager.<init>(DatabaseManager.java:58)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.app.myapp.datamanagement.DataManager.establishDatabase(DataManager.java:45)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.app.myapp.service.MainActivity.onCreate(NoteEditorDialogActivity.java:44)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1891)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1960)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread.access$1500(ActivityThread.java:145)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1045)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.os.Handler.dispatchMessage(Handler.java:99)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.os.Looper.loop(Looper.java:150)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread.main(ActivityThread.java:4369)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at java.lang.reflect.Method.invokeNative(Native Method)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at java.lang.reflect.Method.invoke(Method.java:507)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:846)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:604)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at dalvik.system.NativeStart.main(Native Method)

我还没有尝试重新安装该应用程序,因为我需要保留此错误以进行调试,但我确信它会解决此问题。但是,我确实需要知道为什么会发生此错误以及如何防止它,因此当我发布应用程序时,其他人不会遇到这种致命的崩溃。

注意:系统更新似乎是小更新,因为我在更新前后都停留在2.3.4。

4

2 回答 2

1

看来您缺少依赖 dll(在您的情况下为 'ucol_strcollIter_4_2'....)。这是关于这个错误的讨论。

于 2012-01-24T05:02:29.740 回答
0

首先,您应该将此问题发布到 SQLCipher Google Group:http ://groups.google.com/group/sqlcipher

其次,您使用的是 11 月的 SQLCipher v1 aka 0.0.6 的最终版本吗?https://github.com/downloads/sqlcipher/android-database-sqlcipher/SQLCipherForAndroid-SDK-0.0.6-FINAL.zip

我问是因为您似乎遇到了与链接特定内部库有关的问题,这在 Android 的 SQLCipher 的早期版本中更为常见。

请尝试 Android Market 中的“NoteCipher”应用程序,如果它也有效,请告诉我,因为它还包括 SQLCipher。

于 2012-01-24T05:40:17.020 回答