2

私のアプリandroidでは、次の場所からsqliteデータベースにアクセスできます。

1)Androidを60秒ごとにサービスします。

2)ボタンを押した後(onclik)

サービスがデータベースにアクセスしているときにボタンを押すと、エラーが発生します。

そこで、データベースにアクセスする前に、onclickListenerにstopService()の呼び出しを挿入します。

ただし、データベースにアクセスする前にstopService()を呼び出しても、この後はサービスが停止するため、競合は残ります。

私は使ってみました:

private boolean isMyServiceRunning() {
    ActivityManager manager = (ActivityManager)  getSystemService(Context.ACTIVITY_SERVICE);
    for (RunningServiceInfo service : manager.getRunningServices(Integer.MAX_VALUE)) {
        if ("com.example.MyService".equals(service.service.getClassName())) {
           return true;
        }
    }
    return false;
 }

サービスがAndroidで実行されているかどうかを確認する方法で提案されていますか?

データベースにアクセスする前に、次の方法でこのメソッドを呼び出そうとしました。

    while(isMyServiceRunning())
    {
        // do nothing
    }

    // *** access to my database ***

データベースにアクセスする前にサービスが停止していることを確認するにはどうすればよいですか?

エラーは次のとおりです。

10-30 21:05:43.360: E/SQLiteDatabase(13960): Failed to open the database. closing it.
10-30 21:05:43.360: E/SQLiteDatabase(13960):        android.database.sqlite.SQLiteDatabaseLockedException: database is locked
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at android.database.sqlite.SQLiteDatabase.native_setLocale(Native Method)
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at android.database.sqlite.SQLiteDatabase.setLocale(SQLiteDatabase.java:2115)
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:984)
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:956)
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:1021)
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:753)
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:221)
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:149)
10-30 21:05:43.360: E/SQLiteDatabase(13960):    at host.database.DB_DatabaseManager.open(DB_DatabaseManager.java:134)
4

1 に答える 1

1

onDestroy()サービスのイベントをオーバーライドして、そのデータベースにアクセスしてみることができます。

@Override
public void onDestroy() {
    // *** access to my database ***
    super.onDestroy();
}
于 2012-10-30T20:34:46.340 に答える