I am doing some sort of benchmark for sqlite android. If I were to pre-load total of 120k before executing, will most device have enough memory? While the queries are executing, there are also other threads that are going on so memory might be the problem. How can I make use of the onLowMemory() method? There doesn’t seem to be much examples on using that method. Thanks for any advice.
Share
Making use of the method is as easy as overriding it in your Activity.
However, read the documentation carefully:
I’m not sure (and the docs don’t define) if “background process” includes
AsyncTaskinstances and services, or just backgrounded applications, but I would guess so.So, when this method is called (if it is ever called) the System has already killed everything it could (with lower priorities than your Activity) and now asks you to release any unnecessary resources in memory.
So, If you want to react on low memory, this might be too late already.
As for the general question if most Android devices would run out of memory, I don’t know. The problem is, that devices vary a lot.
I also find it hard to imagine any real live situation, in which you would need to pre-load (or stack) 120k queries before executing. You could easily stack 200 and commit those, than stack another 200 and so on.
I’m not sure why you need to benchmark this, but please don’t execute 120k queries for default entries in your applications database.
You can deliver your application with a filled database and copy it over from the
assets/-folder. See android-sqlite-asset-helper