Недавно я начал получать следующую ошибку в своем приложении. Это НЕ в каком-либо конкретном месте, и я могу воспроизвести только в том случае, если цикл проходит через все функции чтения/записи данных. Это все происходит где угодно.
09-14 08:52:15.089: WARN/SQLiteConnectionPool(19268): The connection pool for database '/data/data/com.nnn/databases/data.db' has been unable to grant a connection to thread 1 (main) with flags 0x5 for 30.000002 seconds.
Connections: 0 active, 1 idle, 0 available.
Есть ли способ избежать этого? Я понимаю, что каким-то образом я исключаю все подключения к базе данных? Я использую подход № 1: http://www.androiddesignpatterns.com/2012/05/correctly-managing-your-sqlite-database.html
И мой код базы данных выглядит следующим образом:
public class DatabaseHelper extends SQLiteOpenHelper
{
private final static String LOG_TAG = "com.nnnn.data.DatabaseHelper";
private static final String DATABASE_NAME = "data.db";
private static final int DATABASE_VERSION = 260;
private static SQLiteDatabase databaseInstance;
public DatabaseHelper()
{
super(MyApplication.Me, DATABASE_NAME, null, DATABASE_VERSION);
}
public static synchronized SQLiteDatabase getDatabase()
{
if (databaseInstance == null) databaseInstance = (new DatabaseHelper()).getWritableDatabase();
return databaseInstance;
}