Adobe Air SQLite: синхронный тайм-аут занятости / параллельный доступ SQLite / цикл избегания занятости
Это мой первый пост здесь. Я спрашиваю, потому что у меня закончились подсказки, и я не смог ничего найти по этому конкретному вопросу.
У меня такой вопрос: есть ли в Adobe AIR способ сделать синхронный эквивалент usleep() (задержка выполнения 200 мс), или есть способ указать где-нибудь время ожидания занятости SQLite?
У меня есть приложение AIR, которое использует базу данных в синхронном режиме, потому что код не может справиться с необходимостью событий / обратных вызовов в запросах SQL.
Иногда к базе данных обращаются из другого приложения, так что она занята. Следовательно, execute() оператора выдает SQLerror 3119 деталь 2206. В этом случае команда должна быть повторена после небольшой задержки.
Поскольку на компьютере запущено другое приложение, я хочу попытаться избежать занятого ожидания, однако я застрял с ним из-за трех вещей:
Во-первых, мне не удалось найти способ присвоить SQLConnection значение тайм-аута занятости, как это возможно в C с помощью функции sqlite3_busy_timeout()
Во-вторых, мне не удалось найти эквивалент команды C usleep() в Adobe AIR / Actionscript.
В-третьих, я не могу использовать события / таймеры / обратные вызовы и т. Д. В этом месте. SQL execute() должен быть синхронным, потому что он вызывается из глубоко вложенных классов и функций в миллионе мест по всему приложению.
Если бы приложение могло справляться с событиями / обратными вызовами во время выполнения SQL, я бы все равно использовал асинхронную базу данных, поэтому эту проблему нельзя решить с помощью событий. Повторная попытка должна быть выполнена на самом низком уровне без использования средства обработки событий AIR.
Самый низкий уровень кода выглядит так:
private static function retried(fn:Function):void {
var loops:int = 0;
for (;;) {
try {
fn();
if (loops)
trace("database available again, "+loops+" loops");
return;
} catch (e:Error) {
if (e is SQLError && e.errorID==3119) {
if (!loops)
trace("database locked, retrying");
loops++;
// Braindead AIR does not provide a synchronous sleep
// so we busy loop here
continue;
}
trace(e.getStackTrace());
trace(e);
throw e;
}
}
}
Пример использования этой функции:
protected static function begin(conn:SQLConnection):void {
retried(function():void{
conn.begin(SQLTransactionLockType.EXCLUSIVE);
});
}
Вывод этого кода выглядит примерно так:
database locked, retrying
database available again, 5100 loops
Читайте: приложение зацикливается более 500 раз в секунду. Я хотел бы уменьшить это до 5 циклов как-то, чтобы уменьшить нагрузку на процессор во время ожидания, потому что приложение должно работать на ноутбуках, а на батарее.
Благодарю.
-Tino