Androidバージョン4.0.4のSamsungNoteでアプリケーションを実行しています。
android2.2を実行しているSamsungPOPなどのデバイスではクラッシュしません。Androi3.1を実行しているMotorolaXoomで。
アプリケーションをインストールすると、黒い画面が表示され、しばらくするとアプリケーションが停止しているというポップアップが表示されます。[OK]を押すと、このダイアログの後ろにアプリケーションのスプラッシュ画面が読み込まれ、ダイアログが消えて、アプリケーションのログイン画面に移動できます。
12-13 18:33:53.823: I/ActivityThread(14608): Pub com.android.mypype.urbanairship.provider: com.urbanairship.UrbanAirshipProvider
12-13 18:33:53.833: I/Inside MyPype(14608): Application Class
12-13 18:33:54.423: D/myPype - UALib(14608): Airship Take Off! Lib Version: 2.0.1 / App key = xsXcmKOoRe6gog9onrQHjA
12-13 18:33:54.423: D/myPype - UALib(14608): In Production? false
12-13 18:33:54.713: D/myPype - UALib(14608): Initializing Push.
12-13 18:33:54.718: D/myPype - UALib(14608): Initializing Analytics.
12-13 18:33:54.938: I/SqliteDatabaseCpp(14608): sqlite returned: error code = 5, msg = database is locked, db=xxx
12-12 11:57:09.553: E/SqliteDatabaseCpp(3608): sqlite3_exec - Failed to set synchronous mode = 1(Normal)
12-12 11:57:09.553: E/SQLiteDatabase(3608): Failed to open the database. closing it.
12-12 11:57:09.553: E/SQLiteDatabase(3608): android.database.sqlite.SQLiteDatabaseLockedException: database is locked
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.database.sqlite.SQLiteDatabase.dbopen(Native Method)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:1132)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:1083)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:1170)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:844)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:228)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:157)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at com.urbanairship.analytics.EventDataManager.<init>(Unknown Source)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at com.urbanairship.analytics.Analytics.<init>(Unknown Source)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at com.urbanairship.UAirship.takeOff(Unknown Source)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at com.android.mypype.MypypeApplication.onCreate(MypypeApplication.java:133)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:972)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.app.ActivityThread.handleBindApplication(ActivityThread.java:3965)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.app.ActivityThread.access$1300(ActivityThread.java:127)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.os.Handler.dispatchMessage(Handler.java:99)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.os.Looper.loop(Looper.java:137)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at android.app.ActivityThread.main(ActivityThread.java:4511)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at java.lang.reflect.Method.invokeNative(Native Method)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at java.lang.reflect.Method.invoke(Method.java:511)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:980)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:747)
12-12 11:57:09.553: E/SQLiteDatabase(3608): at dalvik.system.NativeStart.main(Native Method)
12-12 11:57:09.553: E/myPype - UALib(3608): Unable to open Analytics Event DB
12-12 11:57:37.958: E/myPype - UALib(3608): Unable to get DB size. Database not open.
12-12 11:57:37.963: E/myPype - UALib(3608): Unable to insert event. Database not open.
上記のエラーで、なぜアプリケーションクラスUrbanairship.takeOff()メソッドを指しているのか。
この問題を探していますが、まだ何も取得していません。私はそれを理解することができません。openHelpercalssでデータベース操作のロックを同期してみました。
どんな助けでもありがたいです。
私のApplicationクラスでは、Urbanairshipの以下のコードを追加しました。
@Override
public void onCreate() {
// TODO Auto-generated method stub
super.onCreate();
// This can be done in code as illustrated here,
// or you can add these settings to a properties file
// called airshipconfig.properties
// and place it in your "assets" folder
AirshipConfigOptions options = AirshipConfigOptions
.loadDefaultOptions(this);
// Take off initializes the services
UAirship.takeOff(this, options);
PushManager.enablePush();
}