android - 解析大型 json 响应时出现内存不足错误

标签 android json out-of-memory stringbuilder

我有一个很大的 json 响应。我将它存储在一个字符串中。但是我在解析这个 json 时遇到了内存不足的错误。
我是这样解析的

public ArrayList<String> parsing()
   {
   System.out.println("parsing start");
   ArrayList<String> urls=new ArrayList<String>();

   smusicname=null;smoviename=null;
   sbookname=null;stelevisionname=null;

   int position=0;
    try {  
    JSONObject node1=new JSONObject(response);              
    JSONArray array1=node1.getJSONArray("data");
    int length=array1.length();
    for(int i=0;i<length;i++){
        if(array1.getJSONObject(i).getString("id").equals(friendId.toString())){
            position=i;
        }
    }
       JSONObject node2 = array1.getJSONObject(position);
          try{
              if(node2.has("music"))  {
                 JSONArray array2=node2.getJSONObject("music").getJSONArray("data");
                JSONObject node4=array2.getJSONObject(0);

                String name=node4.getString("name");
                smusicname=name;
                JSONObject node5=node4.getJSONObject("picture");
                JSONObject node6=node5.getJSONObject("data");
                String musicsurl=node6.getString("url");
                urls.add(musicsurl);                  }
                }
          catch(JSONException e)    {
              e.printStackTrace();
            }
          try{
              if(node2.has("movies")){
                  JSONArray array2=node2.getJSONObject("movies").getJSONArray("data");
                JSONObject node4=array2.getJSONObject(0);
                String name=node4.getString("name");
                smoviename=name;
                JSONObject node5=node4.getJSONObject("picture");
                JSONObject node6=node5.getJSONObject("data");
                String moviesurl=node6.getString("url");
                urls.add(moviesurl);
              }
              }
              catch(JSONException e){
                  e.printStackTrace();
                }
          try{
              if(node2.has("books")) {
              JSONArray array2=node2.getJSONObject("books").getJSONArray("data");
                JSONObject node4=array2.getJSONObject(0);
                String name=node4.getString("name");
                sbookname=name;
                JSONObject node5=node4.getJSONObject("picture");
                JSONObject node6=node5.getJSONObject("data");
                String bookurl=node6.getString("url");
                urls.add(bookurl);

              }
          }
              catch(JSONException e){
                e.printStackTrace();
              }
          try{
              if(node2.has("television")) {
              JSONArray array2=node2.getJSONObject("television").getJSONArray("data");
                JSONObject node4=array2.getJSONObject(0);
                String name=node4.getString("name");
                stelevisionname=name;
                JSONObject node5=node4.getJSONObject("picture");
                JSONObject node6=node5.getJSONObject("data");
                String televisionsurl=node6.getString("url");
                urls.add(televisionsurl);
              }
          }
              catch(JSONException e) {
                e.printStackTrace();
              }
        } catch (Exception e) {
            Log.i("JSONException", e.getMessage());
    }
    return urls;
   }`

内存不足

JSONObject node1=new JSONObject(response);
其中 response 是我存储 json 响应的字符串。

这是我的 logcat 消息

`07-25 09:47:21.906: E/dalvikvm-heap(1055): Out of memory on a 634-byte allocation.
07-25 09:47:21.906: I/dalvikvm(1055): "AsyncTask #9" prio=5 tid=17 RUNNABLE JIT
07-25 09:47:21.906: I/dalvikvm(1055):   | group="main" sCount=0 dsCount=0 obj=0x4101bd90 self=0x2a929320
07-25 09:47:21.916: I/dalvikvm(1055):   | sysTid=1144 nice=10 sched=0/0 cgrp=apps/bg_non_interactive handle=714125688
07-25 09:47:21.916: I/dalvikvm(1055):   | state=R schedstat=( 1364254144 10263103582 272 ) utm=129 stm=7 core=0
07-25 09:47:21.916: I/dalvikvm(1055):   at java.lang.AbstractStringBuilder.enlargeBuffer(AbstractStringBuilder.java:~94)
07-25 09:47:21.926: I/dalvikvm(1055):   at java.lang.AbstractStringBuilder.append0(AbstractStringBuilder.java:162)
07-25 09:47:21.926: I/dalvikvm(1055):   at java.lang.StringBuilder.append(StringBuilder.java:311)
07-25 09:47:21.926: I/dalvikvm(1055):   at org.json.JSONTokener.nextString(JSONTokener.java:212)
07-25 09:47:21.926: I/dalvikvm(1055):   at org.json.JSONTokener.nextValue(JSONTokener.java:107)
07-25 09:47:21.926: I/dalvikvm(1055):   at org.json.JSONTokener.readObject(JSONTokener.java:385)
07-25 09:47:21.926: I/dalvikvm(1055):   at org.json.JSONTokener.nextValue(JSONTokener.java:100)
07-25 09:47:21.956: I/dalvikvm(1055):   at org.json.JSONTokener.readObject(JSONTokener.java:385)
07-25 09:47:21.956: I/dalvikvm(1055):   at org.json.JSONTokener.nextValue(JSONTokener.java:100)
07-25 09:47:21.956: I/dalvikvm(1055):   at org.json.JSONTokener.readObject(JSONTokener.java:385)
07-25 09:47:21.966: I/dalvikvm(1055):   at org.json.JSONTokener.nextValue(JSONTokener.java:100)
07-25 09:47:21.966: I/dalvikvm(1055):   at org.json.JSONTokener.readArray(JSONTokener.java:430)
07-25 09:47:21.966: I/dalvikvm(1055):   at org.json.JSONTokener.nextValue(JSONTokener.java:103)
07-25 09:47:21.966: I/dalvikvm(1055):   at org.json.JSONTokener.readObject(JSONTokener.java:385)
07-25 09:47:21.966: I/dalvikvm(1055):   at org.json.JSONTokener.nextValue(JSONTokener.java:100)
07-25 09:47:21.966: I/dalvikvm(1055):   at org.json.JSONObject.<init>(JSONObject.java:154)
07-25 09:47:21.966: I/dalvikvm(1055):   at org.json.JSONObject.<init>(JSONObject.java:171)
07-25 09:47:21.966: I/dalvikvm(1055):   at com.facebook.androidd.MyFragment.parsing(MyFragment.java:662)
07-25 09:47:21.966: I/dalvikvm(1055):   at com.facebook.androidd.MyFragment$DownloadImagesTask1.doInBackground(MyFragment.java:432)
07-25 09:47:21.966: I/dalvikvm(1055):   at com.facebook.androidd.MyFragment$DownloadImagesTask1.doInBackground(MyFragment.java:1)
07-25 09:47:21.966: I/dalvikvm(1055):   at android.os.AsyncTask$2.call(AsyncTask.java:287)
07-25 09:47:21.966: I/dalvikvm(1055):   at java.util.concurrent.FutureTask.run(FutureTask.java:234)
07-25 09:47:21.966: I/dalvikvm(1055):   at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
07-25 09:47:21.966: I/dalvikvm(1055):   at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
07-25 09:47:21.966: I/dalvikvm(1055):   at java.lang.Thread.run(Thread.java:856)`

请帮助我。

最佳答案

您不应该寻求像增加堆大小这样糟糕的解决方案。它可能会暂时解决您的问题,但在某些时候(如果 JSON 变得比它可以存储在内存中的大),它会再次崩溃。

正确和真实的方法是使用GSON streaming。你可以用谷歌搜索或查看 this关联。这也不是很难。玩得开心! ;)

PS:还有其他方法可以做到这一点,例如我读到你可以使用 Jackson 代替 GSON 并且有这个 JsonReader Android SDK (API 11+) 中的类来执行相同的操作。

关于android - 解析大型 json 响应时出现内存不足错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17855045/

相关文章:

java - 如何在 SearchView 上使用 setError()?

iPhone RestKit 如何加载本地 JSON 文件并将其映射到核心数据实体?

javascript - 通过 ID 从数组中获取特定 JSON 对象并返回 JSON 对象 (Javascript/JQuery)

iOS - 何时加载 JSON 数据

java.lang.OutOfMemoryError - new int[Integer.MAX_VALUE];

ruby - 无法在 Ruby 中分配内存(无 MemoryError)?

Python - 超越 RAM 限制?

java - 从 Java 中的 Firebase 实时数据库中选择随机条目

java - 如何使 ImageView 的高度成为图像的高度?安卓

php - Android C2DM 缺少注册错误?