在AsyncTask

时间:2016-01-20 15:51:14

标签: android android-asynctask baseadapter

我正在实现一个名为MyAdapter的类,它扩展了BaseAdapter。在类myAdapter中,我实现了一个名为AttemptLike的类,它扩展了AsyncTask。在Ontind doInBackground函数的类AttemptLike中,我无法使用finish();因此,当我调用Attemptlike类时,我的应用程序每次都会崩溃。所以请告诉我如何处理错误。

代码就像这样

 class MyAdapter extends BaseAdapter{
 .
 .
 .
  public class Attemptlike extends AsyncTask<String, String, String>{
  {
  protected String doInBackground(String... args) 
  {
  try 
                { 
                    List<NameValuePair> params = new ArrayList<NameValuePair>();
                    params.add(new BasicNameValuePair("somedata1", field1)); 
                    params.add(new BasicNameValuePair("somedata2", field2));
 params.add(new BasicNameValuePair("geteventdata", evnt));
                    Log.d("request!", "starting"); 
                    JSONObject json = jsonParser.makeHttpRequest( LOGIN_URL, "POST", params);
                    // checking log for json response 
                    Log.d("Login attempt", json.toString()); 
                    // success tag for json 
                    success = json.getInt(TAG_SUCCESS); 
                    if (success == 1) 
                    { 
                        Log.d("Successfully Liked!", json.toString());

                        finish();
                        // this finish() method is what i am not able use which is resulting in crashing of app
                    }  
                catch (JSONException e) 
                { 
                    e.printStackTrace();
                } 
                return null; 
                }  

        }

        new AttemptLogin().execute();
   return convertView;
   }

 }

栈跟踪

FATAL EXCEPTION: AsyncTask #1
Process: ks.developers.festo, PID: 29568
java.lang.RuntimeException: An error occured while executing doInBackground()
at android.os.AsyncTask$3.done(AsyncTask.java:304)
at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355) 
at java.util.concurrent.FutureTask.setException(FutureTask.java:222) 
at java.util.concurrent.FutureTask.run(FutureTask.java:242)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
at      java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at  java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:818)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method     'java.lang.String org.json.JSONObject.toString()' on a null object reference
at ks.developers.festo.list.adapter.MyAdapter$2$1AttemptLike.doInBackground(MyAdapter.java:237)
at ks.developers.festo.list.adapter.MyAdapter$2$1AttemptLike.doInBackground(MyAdapter.java:1)
at android.os.AsyncTask$2.call(AsyncTask.java:292)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
... 4 more

2 个答案:

答案 0 :(得分:1)

你不能在AsyncTask中使用像那样的完成。它是一种活动的成员方法。

您可能想尝试将其置于runOnUiThread()内或将比赛传递给AsyncTask并使用上下文调用finish()

没有亲自尝试过,但我打赌第一个工作。

查看您现在粘贴的堆栈跟踪后更新:

你真的在这一行有一个NPE:

Log.d("Login attempt", json.toString()); 

json为null,因此您根本没有获取数据。永远不会达到finish()因为当你试图记录json时,在toString()调用之前NPE被抛出很多。首先修复它,看它是否有效。如果仍然没有,请尝试上述方法之一。

答案 1 :(得分:0)

将结果传递给asynctask#onpostexecute并从那里调用finish。 Finish与ui线程交互,必须从该线程调用。你的asynctask在另一个线程上执行。在post上执行在调用线程上执行,因此完成将起作用。