40

私は共通のクラスを持っていAsyncTaskます.onPreExecutedoinbackgroundonPostExecute

現在、クラス A オブジェクトを使用したい他のクラスがあります。

クラスBが以下の方法でクラスAを使用するとします

A a = new A(context)
a.execute(url)

次に、get メソッドで結果をフェッチします。しかし、get メソッドは AsyncTask を使用する適切な方法ではありません。で結果を取得したいと思いonPostExecuteます。そのために、 でのみ true になるブール値パラメーターを使用してみましたonpostexecute。クラス 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;
}
}

'

誰かが私に何が問題なのか教えてもらえますか?

よろしく

スニル

4

3 に答える 3

138

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 メソッドが自動的に呼び出されます。そこでタスクの結果を処理できるようにします。

于 2010-07-20T15:37:36.700 に答える
7
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();



}
于 2012-03-11T19:36:03.960 に答える
1

クラス A を親クラスに埋め込まれたプライベート クラスにします。作業が完了したら、親クラスのプロパティを更新する必要があります。これは onPostExecute で可能です。

于 2010-07-20T15:25:04.820 に答える