使用json对象进行内存管理的问题

时间:2014-10-30 06:19:26

标签: android json out-of-memory

我在" Odoo_database_json"有一个内存管理问题。当我从odoo服务器同步它时,因为它从包含图像的odoo服务器接收到一个巨大的JSON对象,给我一个内存不足的错误。

我尝试过垃圾收集,修剪内存和位图回收()等事情。

public class Databasetask extends AsyncTask<Void, Void, Void> {

    @Override
    protected Void doInBackground(Void... params) {
        // TODO Auto-generated method stub

        try {
            Odoo o = new Odoo("http://10.0.2.2:8089");
            JSONArray database_list = o.getDatabaseList();
            Log.e("database_list.", database_list.toString());

            // Log.e("qqqqqqqqqq.", j1.toString());
            o.authenticate("admin", "a", "demo");// =========>aa set karvanu
            // che

            JSONArray fields = new JSONArray();
            fields.put("city");
            fields.put("name");
            fields.put("phone");
            fields.put("image");
            fields.put("create_date");
            fields.put("write_date");

            // android.os.Debug.dumpHprofData("com.serpentcs.AIOS8.hprof");
            // Debug.dumpHprofData("com.serpentcs.AIOS8.hprof");
            // System.gc();

            JSONObject jsonParams = new JSONObject();
            jsonParams.put("fields", fields);

            // Odoo_database_json=null;
            //==================================================================Error at here because of heap momory is full when i sync data from Odoo server
            Odoo_database_json = o.search_read(Modle, jsonParams); //<==error at here

            jsonArray_items = Odoo_database_json.getJSONArray("records");

            // int x = TRIM_MEMORY_COMPLETE;
            // Log.e("x....",""+x);

            // table exxist ...if u change filed pls..remove it
            tableExist = exists("res_partner");
            Log.e("table", "" + tableExist);
            // if exist does not create table
            if (tableExist) {
                Log.e("Log.....", "Table is exist");

            } else {
                Log.e("Log.....", "Table is not exist");
                JSONObject a = jsonArray_items.getJSONObject(1);

                Iterator<?> key_fields = a.keys();// ===givs fields

                myhelper = new OdooHelper(Listview_contect.this);
                myhelper.makeTable(key_fields);

            }

            // // ==get the records and put it into database..
            //
            publishProgress();
            // //uncaughtException
            // // Log.e("qqqqqqqqqq.", "fgh");

        } catch (ClientProtocolException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (OVersionException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (JSONException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (OutOfMemoryError e) {
            // TODO: handle exception
            e.printStackTrace();
        }

........................... 抱歉,我不知道如何添加新代码,因为我是新的..user..pls任何人编辑它..

 10-30 13:14:50.692: E/dalvikvm-heap(1419): Out of memory on a 2097168-byte allocation.
10-30 13:14:50.692: I/dalvikvm(1419): "AsyncTask #1" prio=5 tid=11 RUNNABLE
10-30 13:14:50.692: I/dalvikvm(1419):   | group="main" sCount=0 dsCount=0 obj=0xb4e89628 self=0xb767e758
10-30 13:14:50.692: I/dalvikvm(1419):   | sysTid=1435 nice=10 sched=0/0 cgrp=apps/bg_non_interactive handle=-1217926224
10-30 13:14:50.702: I/dalvikvm(1419):   | state=R schedstat=( 22190000000 5900000000 5215 ) utm=2068 stm=151 core=0
10-30 13:14:50.702: I/dalvikvm(1419):   at java.util.Scanner.expandBuffer(Scanner.java:~2067)
10-30 13:14:50.702: I/dalvikvm(1419):   at java.util.Scanner.readMore(Scanner.java:2031)
10-30 13:14:50.702: I/dalvikvm(1419):   at java.util.Scanner.findDelimiterAfter(Scanner.java:2009)
10-30 13:14:50.702: I/dalvikvm(1419):   at java.util.Scanner.setTokenRegion(Scanner.java:1923)
10-30 13:14:50.702: I/dalvikvm(1419):   at java.util.Scanner.hasNext(Scanner.java:541)
10-30 13:14:50.702: I/dalvikvm(1419):   at java.util.Scanner.hasNext(Scanner.java:519)
10-30 13:14:50.702: I/dalvikvm(1419):   at odoo.Odoo.convertStreamToString(Odoo.java:1140)
10-30 13:14:50.702: I/dalvikvm(1419):   at odoo.Odoo.requestData(Odoo.java:460)
10-30 13:14:50.702: I/dalvikvm(1419):   at odoo.Odoo.search_read(Odoo.java:726)
10-30 13:14:50.702: I/dalvikvm(1419):   at odoo.Odoo.search_read(Odoo.java:771)
10-30 13:14:50.702: I/dalvikvm(1419):   at com.serpentcs.client.Listview_contect$Databasetask.doInBackground(Listview_contect.java:188)
10-30 13:14:50.702: I/dalvikvm(1419):   at com.serpentcs.client.Listview_contect$Databasetask.doInBackground(Listview_contect.java:1)
10-30 13:14:50.702: I/dalvikvm(1419):   at android.os.AsyncTask$2.call(AsyncTask.java:288)
10-30 13:14:50.702: I/dalvikvm(1419):   at java.util.concurrent.FutureTask.run(FutureTask.java:237)
10-30 13:14:50.702: I/dalvikvm(1419):   at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
10-30 13:14:50.712: I/dalvikvm(1419):   at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
10-30 13:14:50.712: I/dalvikvm(1419):   at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
10-30 13:14:50.712: I/dalvikvm(1419):   at java.lang.Thread.run(Thread.java:841)
10-30 13:14:50.712: W/System.err(1419): java.lang.OutOfMemoryError
10-30 13:14:50.712: W/System.err(1419):     at java.util.Scanner.expandBuffer(Scanner.java:2067)
10-30 13:14:50.722: W/System.err(1419):     at java.util.Scanner.readMore(Scanner.java:2031)
10-30 13:14:50.722: W/System.err(1419):     at java.util.Scanner.findDelimiterAfter(Scanner.java:2009)
10-30 13:14:50.722: W/System.err(1419):     at java.util.Scanner.setTokenRegion(Scanner.java:1923)
10-30 13:14:50.722: W/System.err(1419):     at java.util.Scanner.hasNext(Scanner.java:541)
10-30 13:14:50.732: W/System.err(1419):     at java.util.Scanner.hasNext(Scanner.java:519)
10-30 13:14:50.732: W/System.err(1419):     at odoo.Odoo.convertStreamToString(Odoo.java:1140)
10-30 13:14:50.732: W/System.err(1419):     at odoo.Odoo.requestData(Odoo.java:460)
10-30 13:14:50.732: W/System.err(1419):     at odoo.Odoo.search_read(Odoo.java:726)
10-30 13:14:50.732: W/System.err(1419):     at odoo.Odoo.search_read(Odoo.java:771)
10-30 13:14:50.732: W/System.err(1419):     at com.serpentcs.client.Listview_contect$Databasetask.doInBackground(Listview_contect.java:188)
10-30 13:14:50.732: W/System.err(1419):     at com.serpentcs.client.Listview_contect$Databasetask.doInBackground(Listview_contect.java:1)
10-30 13:14:50.732: W/System.err(1419):     at android.os.AsyncTask$2.call(AsyncTask.java:288)
10-30 13:14:50.732: W/System.err(1419):     at java.util.concurrent.FutureTask.run(FutureTask.java:237)
10-30 13:14:50.732: W/System.err(1419):     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
10-30 13:14:50.732: W/System.err(1419):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
10-30 13:14:50.732: W/System.err(1419):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
10-30 13:14:50.732: W/System.err(1419):     at java.lang.Thread.run(Thread.java:841)    

0 个答案:

没有答案