Android AsyncTask和Handler对比,ProgressBar的用法

来源:互联网 发布:h海南大学网络 编辑:程序博客网 时间:2024/05/20 14:23


下面我用AsyncTaks会写一个ProgressBar的用法


Android AsyncTask和Handler对比

1 AsyncTask实现原理 优点和缺点

AsyncTaks 是android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操作,并且提供接口反馈当前异步执行的程度(可以通过接口实现UI进度更新),最后反馈执行的结果给主线程

 优点 

简单 快捷 过程可控

缺点

 在使用多个异步操作并需要进行UI变更时,就变得复杂起来

 2  Hander异步实现原理 优点和缺点

在Handler异步实现时 设计到Handler Looper Message Thread 四个对象,实现异步的流程是主线程中启动(Thread)子线程
athread(子线程) 运行并生成Message-aLooper获取Message并传递给HandleraHandler卓哥获取Looper中的Message中的Message
并进行UI变更
 优点
 结构清晰 功能定义明确 对于多个后台任务时 简单 清晰
缺点
在单个后台异步处理时 显得代码过多 结构过于复杂


AsyncTaks介绍

比Handler更轻量级,使用于简单的异步处理。
由于主线程只有一个 为了防止主线程阻塞 
而且更新UI的操作 只能放在主线程 所以就出现了Handler和AsyncTask
异步处理不可避免的

Android为了降低这个开发难度,提供了AsyncTask。AsyncTask就是一个封装过的后台任务类,顾名思义就是异步任务。

AsyncTask直接继承于Object类,位置为android.os.AsyncTask。要使用AsyncTask工作我们要提供三个泛型参数,并重载几个方法(至少重载一个)。

 

AsyncTask定义了三种泛型类型 Params,Progress和Result。

  • Params 启动任务执行的输入参数,比如HTTP请求的URL。
  • Progress 后台任务执行的百分比。
  • Result 后台执行任务最终返回的结果,比如String。

使用过AsyncTask 的同学都知道一个异步加载数据最少要重写以下这两个方法:

  • doInBackground(Params…) 后台执行,比较耗时的操作都可以放在这里。注意这里不能直接操作UI。此方法在后台线程执行,完成任务的主要工作,通常需要较长的时间。在执行过程中可以调用publicProgress(Progress…)来更新任务的进度。
  • onPostExecute(Result)  相当于Handler 处理UI的方式,在这里面可以使用在doInBackground 得到的结果处理操作UI。 此方法在主线程执行,任务执行的结果作为此方法的参数返回

有必要的话你还得重写以下这三个方法,但不是必须的:

  • onProgressUpdate(Progress…)   可以使用进度条增加用户体验度。 此方法在主线程执行,用于显示任务执行的进度。
  • onPreExecute()        这里是最终用户调用Excute时的接口,当任务执行之前开始调用此方法,可以在这里显示进度对话框。
  • onCancelled()             用户调用取消时,要做的操作

使用AsyncTask类,以下是几条必须遵守的准则:

  • Task的实例必须在UI thread中创建;
  • execute方法必须在UI thread中调用;
  • 不要手动的调用onPreExecute(), onPostExecute(Result),doInBackground(Params...), onProgressUpdate(Progress...)这几个方法;
  • 该task只能被执行一次,否则多次调用时将会出现异常;

一个超简单的理解 AsyncTask 的例子:

MainActivity

package com.example.asynctasksimpledemo;import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import android.view.View;import android.widget.Button;import android.widget.ProgressBar;import android.widget.TextView;public class MainActivity extends AppCompatActivity {    private Button button;    private ProgressBar progressBar;    private TextView textView;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        button = (Button)findViewById(R.id.button);        progressBar = (ProgressBar)findViewById(R.id.progressbar);        textView = (TextView)findViewById(R.id.textView);        button.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View v) {                ProgressBarAsyncTask task = new ProgressBarAsyncTask(textView, progressBar);                task.execute(1000);            }        });    }}


NetOperator

package com.example.asynctasksimpledemo;/** * 模拟网络环境 * Name: NetOperator * Author: liuan * creatTime:2017-01-11 11:32 */public class NetOperator {    public void opeartor() {        try {            Thread.sleep(1000);        } catch (InterruptedException e) {            e.printStackTrace();        }    }}


ProgressBarAsyncTask
package com.example.asynctasksimpledemo;import android.os.AsyncTask;import android.widget.ProgressBar;import android.widget.TextView;/** * Name: ProgressBarAsyncTask * Author: liuan * creatTime:2017-01-11 11:33 */public class ProgressBarAsyncTask extends AsyncTask<Integer, Integer, String> {    private final TextView textView;    private final ProgressBar progressBar;    public ProgressBarAsyncTask(TextView textView, ProgressBar progressBar) {        this.textView = textView;        this.progressBar = progressBar;    }    /**     * 该方法步运行在子线程  主要用于异步操作 更新UI的话 应该调用publicshProgress方法(会触发onProgressUpdate对UI进行操作)     * 首先执行的方法     *     * @param params     * @return 就是参数3 也就是String     */    @Override    protected String doInBackground(Integer... params) {        NetOperator netOperator = new NetOperator();        int i = 0;        for (i = 0; i <= 100; i += 10) {            netOperator.opeartor();            publishProgress(i);        }        return i + "%";    }    /**     * doInbackgrout之后执行     *     * @param s     */    @Override    protected void onPostExecute(String s) {        //一般写下载完成        textView.setText("异步操作执行结束" + s);    }    //此方法运行在Ui线程中 可以对UI控件进行设置    @Override    protected void onPreExecute() {        textView.setText("开始执行异步任务");    }    //参数2 在主线程中执行 所有可以对UI控件进行操作    @Override    protected void onProgressUpdate(Integer... values) {        int value = values[0];        progressBar.setProgress(value);    }}


布局

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:id="@+id/activity_main"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:orientation="vertical"    tools:context="com.example.asynctasksimpledemo.MainActivity">    <TextView        android:layout_width="match_parent"        android:layout_height="wrap_content"       android:id="@+id/textView" />    <ProgressBar        style="?android:attr/progressBarStyleHorizontal"        android:layout_width="match_parent"        android:layout_height="wrap_content" android:id="@+id/progressbar"/>    <Button        android:layout_width="match_parent"        android:layout_height="wrap_content" android:id="@+id/button"        android:text="更新progress"/></LinearLayout>



0 0