I use the following code for converting Json string(strWebserviceResult) to my Object:
EntMyClass entMyClass = gson.fromJson(strWebserviceResult,EntMyClass.c
Please, read the answer from the author of gson - here
And my 5 cents:
JsonReader r = null;
try {
Reader reader = new BufferedReader(new InputStreamReader(is));
r = new JsonReader(reader);
result = gson.fromJson(r, clazz);
} finally {
if (null != r) {
r.close();
}
}
Try using the fromJson method that takes a JsonReader as input instead. This should allow you to not need the whole input string to be in memory at one time. Here's some sample code:
final HttpURLConnection c = (HttpURLConnection) url.openConnection();
final InputStreamReader isr = new InputStreamReader(c.getInputStream());
final JsonReader reader = new JsonReader(isr);
final EntMyClass entMyClass = GSON.fromJson(reader, EntMyClass.class);
reader.close();
c.disconnect();
As with the other post, I would ask whether there is any way to avoid large memory usage with your app. If you can do that, it will be the most optimal solution. If your app really needs that much memory, you can try setting android:largeHeap="true"
for your application in the manifest. Here is the reference:
http://developer.android.com/reference/android/R.styleable.html#AndroidManifestApplication_largeHeap
See this video for more information:
http://www.youtube.com/watch?v=_CruQY55HOk
First of all. Do you really need to load 2.5MB data into memory?
At first there is created a big string, then it's parsed (another objects in memory), and then there is created a huge instance of EntMyClass. This approach is really inefficient.
I guess you have List in this object. Having only information you've provided I'd suggest to stream data into database. Then you can create adapter to show data in ListView.
There is a lot of ways how to do it. I'm using Jackson library because is the fastest, GSON should have similar functions.
Assuming you have a list in this object below is example how to store json array in database:
//create parser
final JsonParser jsonParser = objectMapper.getJsonFactory().createJsonParser(inputStream);
JsonToken jsonToken = jsonParser.nextToken();
while ((jsonToken = jsonParser.nextToken()) != null && jsonToken != JsonToken.END_ARRAY) {
//map json object to ItemClass
final ItemClass item = jsonParser.readValueAs(ItemClass.class);
//store in database
itemDAO.insert(item);
}
And surround it with database transaction, not only data will be rollback in case of error but it's also more efficient.