2014-06-25 33 views
0

我似乎无法解决我遇到的这个问题。在我的MainActivity中,我使用几个Asynctasks将我的设备的应用程序数据库与后端数据库同步,每个表都有一个。因为我有很多不同的表,我对的AsyncTask的一般设置,并通过在确定这样的同步处理的表中的参数:AsyncTask中的JSONObject的问题

protected void onResume() { 
    if(isOnline()){ 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ FORENINGAR }); 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ INFO }); 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ KALENDER }); 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ KAMPEN }); 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ KARTA }); 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ KONTAKT }); 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ MEDDELANDEN }); 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ OVRIGINFO }); 
     new loadFromBackendAndPlaceInDB().execute(new Integer[]{ SANGBOK }); 
    } 
} 

实际的AsyncTask看起来像这样:

class loadFromBackendAndPlaceInDB extends AsyncTask<Integer, String, String> { 

    protected String doInBackground(Integer... params) { 

     int activity = params[0]; 
     String url = urlList.get(activity); 
     String json = null; 

     try { 
      URL urlObject = new URL(url); 
      HttpURLConnection con = (HttpURLConnection) urlObject.openConnection(); 
      con.setConnectTimeout(15000); 
      con.setReadTimeout(15000); 
      json = readStream(con.getInputStream()); 
     } catch (Exception e) { 
      e.printStackTrace(); 
     } 

     if(json != null){ 
      JSONObject jObj = null; 
      try { 
       // THIS IS WHERE I'M STARTING GETTING A PROBLEM 
       // LINE 536 
       jObj = new JSONObject(json); 
      } catch (JSONException e1) { 
       // TODO Auto-generated catch block 
       e1.printStackTrace(); 
      } 

      try { 

       // THIS IS WHERE THE RUNTIME ERROR OCCURS BECAUSE OF THE PROBLEM AT ROW 536 
       // LINE 546 
       int success = jObj.getInt(TAG_SUCCESS); 

       if (success == 1) { 
        JSONArray jsonArray = null; 
        jsonArray = jObj.getJSONArray(getActivityTag(activity)); 

        getContentResolver().delete(getContentUri(activity), null, null); 
        for (int i = 0; i < jsonArray.length(); i++) { 

         JSONObject c = jsonArray.getJSONObject(i); 

         ContentValues values = new ContentValues(); 
         for(int k = 0; k < getColumns(activity).size(); k++){ 
          String TAG = getTags(activity).get(k); 
          String VALUE = c.getString(TAG); 
          String COLUMN = getColumns(activity).get(k); 

          values.put(COLUMN, VALUE); 
         } 

         getContentResolver().insert(getContentUri(activity), values); 
        } 
       } else { 
        Log.d("No Success", getActivityTag(activity)); 
       } 


      } catch (JSONException e) { 
       e.printStackTrace(); 
      } 

     }else{ 

     } 

     return null; 
    } 

    protected void onPostExecute(String result) { 
     super.onPostExecute(result); 
    } 

} 

,这就是在的AsyncTask使用的方法readStream:

private String readStream(InputStream in) { 
    BufferedReader reader = null; 
    StringBuilder sb = null; 
    String json = ""; 
    try { 
     reader = new BufferedReader(new InputStreamReader(in)); 
     sb = new StringBuilder(); 
     String line = ""; 
     while ((line = reader.readLine()) != null) { 
      sb.append(line + "\n"); 
     } 
    } catch (IOException e) { 
     e.printStackTrace(); 
    } finally { 
     if (reader != null) { 
      try { 
       reader.close(); 
       in.close(); 
       json = sb.toString(); 
      } catch (IOException e) { 
       e.printStackTrace(); 
      } 
     } 
    } 
    return json; 
} 

这是我的logcat:

06-25 18:43:18.089: W/System.err(3942): org.json.JSONException: End of input at character 0 of 
06-25 18:43:18.113: W/System.err(3942):  at org.json.JSONTokener.syntaxError(JSONTokener.java:446) 
06-25 18:43:18.113: W/System.err(3942):  at org.json.JSONTokener.nextValue(JSONTokener.java:93) 
06-25 18:43:18.113: W/System.err(3942):  at org.json.JSONObject.<init>(JSONObject.java:154) 
06-25 18:43:18.113: W/System.err(3942):  at org.json.JSONObject.<init>(JSONObject.java:171) 
06-25 18:43:18.113: W/System.err(3942):  at se.nollekollen.main.MainActivity$loadFromBackendAndPlaceInDB.doInBackground(MainActivity.java:536) 
06-25 18:43:18.113: W/System.err(3942):  at se.nollekollen.main.MainActivity$loadFromBackendAndPlaceInDB.doInBackground(MainActivity.java:1) 
06-25 18:43:18.113: W/System.err(3942):  at android.os.AsyncTask$2.call(AsyncTask.java:185) 
06-25 18:43:18.113: W/System.err(3942):  at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306) 
06-25 18:43:18.117: W/System.err(3942):  at java.util.concurrent.FutureTask.run(FutureTask.java:138) 
06-25 18:43:18.117: W/System.err(3942):  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088) 
06-25 18:43:18.117: W/System.err(3942):  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581) 
06-25 18:43:18.117: W/System.err(3942):  at java.lang.Thread.run(Thread.java:1019) 
06-25 18:43:18.121: W/dalvikvm(3942): threadid=13: thread exiting with uncaught exception (group=0x40015578) 
06-25 18:43:18.125: E/AndroidRuntime(3942): FATAL EXCEPTION: AsyncTask #5 
06-25 18:43:18.125: E/AndroidRuntime(3942): java.lang.RuntimeException: An error occured while executing doInBackground() 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at android.os.AsyncTask$3.done(AsyncTask.java:200) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:274) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at java.util.concurrent.FutureTask.setException(FutureTask.java:125) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:308) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at java.util.concurrent.FutureTask.run(FutureTask.java:138) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at java.lang.Thread.run(Thread.java:1019) 
06-25 18:43:18.125: E/AndroidRuntime(3942): Caused by: java.lang.NullPointerException 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at se.nollekollen.main.MainActivity$loadFromBackendAndPlaceInDB.doInBackground(MainActivity.java:546) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at se.nollekollen.main.MainActivity$loadFromBackendAndPlaceInDB.doInBackground(MainActivity.java:1) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at android.os.AsyncTask$2.call(AsyncTask.java:185) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306) 
06-25 18:43:18.125: E/AndroidRuntime(3942):  ... 4 more 

看来好像这个问题在线路536然后导致在线路546

最终runtimeerror误差仅有时会出现启动,有时它的罚款。看起来好像是在我快速输入和输入MainActivity时发生的 - 当我在整个应用程序中更慢地导航时,它通常很好。

发生了什么,为什么会发生此错误,解决方案是什么?感谢所有答案!

回答

0

我有问题瓦特/多AsyncTask腐败对方(虽然我没有看到任何明显的错误在您的代码)。

我通常的解决方案是在IntentService中有这样的操作,并通过广播意图传递更新到Activity。

这意味着我在活动内部保留一个BroadcastReceiver来捕捉意图并更新UI。

好运。

0

而不是触发多个AsyncTask为什么不只是发送单个整数数组作为参数为一个和所有的值AsyncTask只是实现循环通过整数数组条目逐一循环。

+0

我试过这个,并且发生了同样的问题 – jahed

+0

当你从你的activity的onResume方法发起调用时,当你导入/导出你的mainactivity时,它会导致多个调用初始化AsyncTask组,导致数据库锁定或导致运行时错误,这是不处理的东西。当你慢慢浏览整个应用程序时,你的asynctasks有足够的时间执行和更新数据库。所以我会建议,当数据库更新开始时把一个进度对话框禁用任何用户交互。 –