Android:AsyncTask onPostExecute收到空回复

时间:2015-10-14 11:55:53

标签: java android multithreading android-asynctask

我正在研究一个Android应用程序,其中我在与活动相同的类中使用AsyncTask。在我有一个线程模型之前我会加入线程并等到我有回复。但是当它锁定UI时,我正在将我的代码迁移到Async-task。顺利进行其他方法,但是我收到的错误是什么都没有收到。

由于服务器本身在localhost中,我正在记录我发出的回复。此外,它很好地适用于Thread。我做错了什么?

错误日志:

10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime: FATAL EXCEPTION: main
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime: Process: internetlegion.twentynotes, PID: 31746
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Object org.springframework.http.ResponseEntity.getBody()' on a null object reference
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at internetlegion.twentynotes.Activity.GroupAccountActivity$getGroupAccountsForLoggedInUser.onPostExecute(GroupAccountActivity.java:125)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at internetlegion.twentynotes.Activity.GroupAccountActivity$getGroupAccountsForLoggedInUser.onPostExecute(GroupAccountActivity.java:108)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at android.os.AsyncTask.finish(AsyncTask.java:632)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at android.os.AsyncTask.access$600(AsyncTask.java:177)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:645)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at android.os.Handler.dispatchMessage(Handler.java:102)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at android.os.Looper.loop(Looper.java:155)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at android.app.ActivityThread.main(ActivityThread.java:5696)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Native Method)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Method.java:372)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1028)
10-14 13:47:00.917 31746-31746/internetlegion.twentynotes E/AndroidRuntime:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:823)

GroupAccountActivity:

public class GroupAccountActivity extends Activity {

    private ResponseEntity<RestGroupAccount[]> responseEntity;

    GroupAccountAdapter groupAccountAdapter;

    final String groupAccountRetrieveURL = StaticRestTemplate.baseURL+"getgroupsforuser/";
 @Override
    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_group_account);

        if(isOnline()) {
            new getGroupAccountsForLoggedInUser().execute();
        }else {
            Toast.makeText(getApplicationContext(),"No Internet connection",Toast.LENGTH_LONG).show();
        }
}
  public class getGroupAccountsForLoggedInUser extends AsyncTask<Void,Void,ResponseEntity<RestGroupAccount[]>>{

        @Override
        protected ResponseEntity<RestGroupAccount[]> doInBackground(Void... params) {
            RestTemplate restTemplate = StaticRestTemplate.getRest();
            HttpHeaders requestHeaders = new HttpHeaders();
            requestHeaders.add("Cookie", "JSESSIONID=" + StaticRestTemplate.jsessionid);
            requestHeaders.setAccept(Collections.singletonList(new MediaType("application", "json")));
            HttpEntity<?> requestEntity = new HttpEntity<Object>(requestHeaders);
            restTemplate.getMessageConverters().add(new MappingJackson2HttpMessageConverter());
            return restTemplate.exchange(groupAccountRetrieveURL, HttpMethod.GET, requestEntity, RestGroupAccount[].class);
        }

        @Override
        protected void onPostExecute(ResponseEntity<RestGroupAccount[]> entity) {
            super.onPostExecute(entity);
// Line below is throwing error.
            RestGroupAccount[] restGroupAccounts = responseEntity.getBody();
            Collections.addAll(restGroupAccountList, restGroupAccounts);

            ArrayList<HashMap<String, String>> groupList = new ArrayList<HashMap<String, String>>();
}

}

请告诉我。非常感谢。 : - )

3 个答案:

答案 0 :(得分:2)

您正在引用onPostExecute中的错误对象。您应该引用结果对象/参数。

将您的代码更改为:

RestGroupAccount[] restGroupAccounts = entity.getBody();

答案 1 :(得分:2)

responseEntity永远不会初始化。

我想你想做

RestGroupAccount[] restGroupAccounts = entity.getBody();

答案 2 :(得分:2)

我想我发现了错误。你做的是

RestGroupAccount[] restGroupAccounts = responseEntity.getBody();

但是在onPostExecute中,响应被称为entity

您在上面声明了responseEntity:

private ResponseEntity<RestGroupAccount[]> responseEntity;

但那个人不包含回应。

尝试更改

RestGroupAccount[] restGroupAccounts = responseEntity.getBody();

RestGroupAccount[] restGroupAccounts = entity.getBody();