我正在实现一个名为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
答案 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上执行在调用线程上执行,因此完成将起作用。