将JSONObject转换为JsonObject抛出内存不足异常

时间:2016-12-13 14:25:02

标签: android json out-of-memory retrofit2 gson

我需要在项目中将JSONObject转换为JsonObject(Gson特定格式)。为此我使用以下方法转换为相同的

public static  JsonObject getJsonFromJSONObject(JSONObject json) {

        JsonObject jsonObject = null;
        try {
            JsonParser jsonParser = new JsonParser();
            jsonObject = (JsonObject) jsonParser.parse(json.toString());

        }catch (Exception e){

            CLog.e(Constants.LOG_TAG, e.getMessage());
        }
        return jsonObject;
    }

在我的应用的测试阶段,一切运作良好。但在一些罕见的现象我内存异常。自从一周以来,我完全被这种情况所困扰,但仍然无法找到任何解决方案。

我得到的错误:

Fatal Exception: java.lang.OutOfMemoryError
      at java.lang.AbstractStringBuilder.enlargeBuffer(AbstractStringBuilder.java:95)
      at java.lang.AbstractStringBuilder.append0(AbstractStringBuilder.java:133)
      at java.lang.StringBuilder.append(StringBuilder.java:124)
      at org.json.JSONStringer.string(JSONStringer.java:344)
      at org.json.JSONStringer.value(JSONStringer.java:252)
      at org.json.JSONArray.writeTo(JSONArray.java:602)
      at org.json.JSONStringer.value(JSONStringer.java:233)
      at org.json.JSONObject.writeTo(JSONObject.java:672)
      at org.json.JSONObject.toString(JSONObject.java:641)
      at com.android.package.http.utils.JSONUtils.getJsonFromJSONObject(Unknown Source)
      at android.app.ActivityThread.handleReceiver(ActivityThread.java:2573)
      at android.app.ActivityThread.access$1700(ActivityThread.java:151)
      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)
      at android.os.Handler.dispatchMessage(Handler.java:110)
      at android.os.Looper.loop(Looper.java:193)
      at android.app.ActivityThread.main(ActivityThread.java:5299)
      at java.lang.reflect.Method.invokeNative(Method.java)
      at java.lang.reflect.Method.invoke(Method.java:515)
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:825)
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:641)
      at dalvik.system.NativeStart.main(NativeStart.java)

上述错误已反映在60万用户中的26,000名用户中。我无法解决这个问题。任何有用的解决方案和建议对我都有帮助。提前谢谢。

1 个答案:

答案 0 :(得分:1)

尝试将JSONObject写入文件,并从文件

中读取为jsonObject

用于编写JSONObject

ObjectOutputStream out = null;
        FileOutputStream fos = null;

        try {
            File file = new File(fc.getLocalCache().getAbsolutePath() + "/" + folderId + ".srl");
            fos = new FileOutputStream(file);

            out = new ObjectOutputStream(fos);
            out.writeObject(response.toString());
        } catch (OutOfMemoryError | Exception e) {
            e.printStackTrace();
        }

阅读对象

try {
            FileInputStream isf = new FileInputStream(new File(fc.getLocalCache() + "/" + folderId + ".srl"));
            ObjectInputStream in = new ObjectInputStream(isf);
            String json = (String) in.readObject();
            JsonParser parser = new JsonParser();
            JsonObject o = parser.parse(json).getAsJsonObject();
            //Gson gSon=  new GsonBuilder().setDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'").create();
            jsonObject = new Item();
            jsonObject.setRawObject(new DefaultSerializer(new DefaultLogger()), o); //new Gson().fromJson(o, Item.class);
            in.reset();
            in.close();
            isf.close();
            // Log.i("jsonObject", jsonObject.toString());
        } catch (Exception e) {
            e.printStackTrace();
            //Log.i("getObjectsFromLocal Exception", e.toString());
            return jsonObject;
        }

注意 要产生内存不足异常,你可能需要低内存移动和json大小,大于2或3MB。(这可能适合你)