AsyncTask
を拡張し、すべてのメソッドを実装したクラスAなどの共通のクラスがあります。つまり、onPreExecute
、doinbackground
、onPostExecute
です。
現在、クラスAオブジェクトを使用したい他のクラスがあります。
クラスBが以下の方法でクラスAを使用するとします
A a = new A(context)
a.execute(url)
次に、結果をgetメソッドでフェッチします。ただし、getメソッドはAsyncTaskを使用する適切な方法ではありません。 onPostExecute
で結果を取得します。そのため、onpostexecute
でのみtrueになるブールパラメータを使用してみました。クラスBは、trueになるまでチェックし、trueになると結果をフェッチします。
しかし、これが何らかの理由でアプリケーションをブロックしています。
以下にasynctaskのコードを配置しました。
」
import Java.io.IOException;
import org.Apache.http.client.ClientProtocolException;
import org.Apache.http.client.HttpClient;
import org.Apache.http.client.ResponseHandler;
import org.Apache.http.client.methods.HttpGet;
import org.Apache.http.impl.client.BasicResponseHandler;
import org.Apache.http.impl.client.DefaultHttpClient;
import Android.app.ProgressDialog;
import Android.content.Context;
import Android.os.AsyncTask;
public class A extends AsyncTask<String, Void, String>
{
private Context context = null;
private final HttpClient httpClient = new DefaultHttpClient();
private String content = null;
//private String error = null;
private String finalResult = null;
private static boolean isResult = false;
private ProgressDialog progressDialog = null;
public BabbleVilleSyncTask(Context context)
{
this.context = context;
progressDialog = new ProgressDialog(this.context);
}
protected void onPreExecute()
{
progressDialog.setMessage("Please Wait....");
progressDialog.show();
}
protected String doInBackground(String... urls)
{
try
{
//urls[0] = URLEncoder.encode(urls[0], "UTF-8");
HttpGet httpget = new HttpGet(urls[0]);
ResponseHandler<String> responseHandler = new BasicResponseHandler();
content = httpClient.execute(httpget, responseHandler);
}
/*catch(UnsupportedEncodingException ue)
{
error = ue.getMessage();
}*/
catch (ClientProtocolException e)
{
//error = e.getMessage();
cancel(true);
}
catch (IOException e)
{
//error = e.getMessage();
cancel(true);
}
httpClient.getConnectionManager().shutdown();
return content;
}
protected void onPostExecute(String result)
{
finalResult = result;
progressDialog.dismiss();
System.out.println("on Post execute called");
isResult = true;
}
public boolean getIsResult()
{
return isResult;
}
public void setIsResult(boolean flag)
{
isResult = flag;
}
public String getResult()
{
return finalResult;
}
}
」
誰かが問題が何であるかを私に知らせることができますか?
よろしく
スニル
AsyncTaskを使用して結果を取得するクリーンな方法は、コールバックインターフェイスを使用することです。
この概念の簡単な例を次に示します。
interface AsyncTaskCompleteListener<T> {
public void onTaskComplete(T result);
}
次に、Bクラスで:
class B implements AsyncTaskCompleteListener<String> {
public void onTaskComplete(String result) {
// do whatever you need
}
public void launchTask(String url) {
A a = new A(context, this);
a.execute(url);
}
}
次のコードをAクラスに追加する必要があります。
class A extends AsyncTask<String, Void, String> {
private AsyncTaskCompleteListener<String> callback;
public A(Context context, AsyncTaskCompleteListener<String> cb) {
this.context = context;
this.callback = cb;
}
protected void onPostExecute(String result) {
finalResult = result;
progressDialog.dismiss();
System.out.println("on Post execute called");
callback.onTaskComplete(result);
}
}
このように、タスクが完了するのを明示的に待つ必要はありません。代わりに、メインコード(おそらくメインUIスレッド)が通常のAndroidイベントループで待機しています。そしてonTaskCompleteメソッドが自動的に呼び出され、そこでタスク結果を処理できるようになります。
public abstract class BaseTask<T> extends AsyncTask<Object, Void, T> {
public Context context;
public ProgressDialog dialog;
public Exception exception;
protected BaseTask() {
}
public BaseTask(Context context) {
this.context = context;
this.dialog = new ProgressDialog(context);
}
@Override
protected void onPreExecute() {
this.dialog.setMessage(context.getResources().getString(R.string.loading));
this.dialog.show();
}
@Override
protected T doInBackground(Object... objects) {
try {
return doWork(objects);
} catch (Exception e) {
exception = e;
}
return null;
}
@Override
protected void onPostExecute(T result) {
if (dialog.isShowing()) dialog.dismiss();
if (exception == null) {
onResult(result);
} else {
onError();
}
}
public abstract T doWork(Object... objects) throws Exception;
public abstract void onResult(T result);
public abstract void onError();
}
クラスAを親クラスに埋め込まれたプライベートクラスにし、作業が完了すると、親クラスのプロパティを更新する必要があります。これは、onPostExecuteで可能です。