Может ли Android использовать дисковое пространство для постановки в очередь транзакции SQLite?Android

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Может ли Android использовать дисковое пространство для постановки в очередь транзакции SQLite?

Сообщение Anonymous »

Я хотел бы совершить крупную транзакцию с помощью Androidx Room, примерно такую:

Код: Выделить всё

@Transaction
fun addGeneratedRows() {
for (i in 0 until 5_000_000) {
addItem(generateRowWhichTakesUpALotOfMemory())
}
}
@Insert fun addItem(itm: MyLargeRow)
Я опасаюсь, что это может привести к ошибке «Недостаточно памяти», если Room сохранит всю транзакцию в оперативной памяти перед ее записью в базу данных.
Но я могу себе представить, что он может буферизовать строки на диске, позволяя сборщику мусора очищать объект между проходами for, поскольку они генерируются на лету.
Ну что, так и будет? Кажется, я не могу найти источник, который бы это делал, но также и нет источника, которого бы это точно не делало.

Подробнее здесь: https://stackoverflow.com/questions/784 ... ransaction
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»