Android:AsyncTask和publishProgress学习

本文详细介绍了Android中AsyncTask的工作原理及其使用方法。包括五个关键阶段:onPreExecute、doInBackground、onProgressUpdate、onPostExecute及onCancelled。通过具体实例展示了如何在实际应用中运用这些回调函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android:AsyncTask和publishProgress学习


一、概述: AsyncTask是在Android SDK 1.5之后推出的一个方便编写后台线程与UI线程交互的辅助类。AsyncTask的内部实现是一个线程池,每个后台任务会提交到线程池中的线程执行,然后使用Thread+Handler的方式调用回调函数。
二、AsyncTask抽象出后台线程运行的五个状态,分别是:1、准备运行,2、正在后台运行,3、进度更新,4、完成后台任务,5、取消任务,对于这五个阶段,AsyncTask提供了五个回调函数:
1、准备运行:onPreExecute(),该回调函数在任务被执行之后立即由UI线程调用。这个步骤通常用来建立任务,在用户接口(UI)上显示进度条。
2、正在后台运行:doInBackground(Params...),该回调函数由后台线程在onPreExecute()方法执行结束后立即调用。通常在这里执行耗时的后台计算。计算的结果必须由该函数返回,并被传递到onPostExecute()中。在该函数内也可以使用publishProgress(Progress...)来发布一个或多个进度单位(unitsof progress)。这些值将会在onProgressUpdate(Progress...)中被发布到UI线程。
3. 进度更新:onProgressUpdate(Progress...),该函数由UI线程在publishProgress(Progress...)方法调用完后被调用。一般用于动态地显示一个进度条。
4. 完成后台任务:onPostExecute(Result),当后台计算结束后调用。后台计算的结果会被作为参数传递给这一函数。
5、取消任务:onCancelled (),在调用AsyncTask的cancel()方法时调用
三、AsyncTask的构造函数有三个模板参数
1.Params,传递给后台任务的参数类型。
2.Progress,后台计算执行过程中,进步单位(progress units)的类型。(就是后台程序已经执行了百分之几了。)
3.Result, 后台执行返回的结果的类型。
四、AsyncTask并不总是需要使用上面的全部3种类型。标识不使用的类型很简单,只需要使用Void类型即可。
五、学习实例。
1、MainActivity.java
package com.example.asynctask;

import android.app.Activity;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.ProgressBar;
import android.view.View.OnClickListener;
import java.lang.String;

public class MainActivity extends Activity implements OnClickListener 
	{ 
	        
	    private TextView textView; 
	    private ProgressBar progressBar; 
	        
	    class MyAsyncTask extends AsyncTask<String, Integer, String> 
	    { 
	        /** 
	         * 异步任务:AsyncTask<Params, Progress, Result> 
	         * 1.Params:UI线程传过来的参数。 
	         * 2.Progress:发布进度的类型。 
	         * 3.Result:返回结果的类型。耗时操作doInBackground的返回结果传给执行之后的参数类型。 
	         * 
	         * 执行流程: 
	         * 1.onPreExecute() 
	         * 2.doInBackground()-->onProgressUpdate() 
	         * 3.onPostExecute() 
	         */
	        @Override                      
	        protected void onProgressUpdate(Integer... values)//执行操作中,发布进度后 
	        { 
	            progressBar.setProgress(values[0]);//每次更新进度条 
	            String str = Integer.toString(values[0]);
	            textView.setText(str); 
	        } 
	        @Override
	        protected void onPreExecute()//执行耗时操作之前处理UI线程事件 
	        { 
	            progressBar.setVisibility(View.VISIBLE);//点击之后,下载执行之前,设置进度条可见 
	        } 
	            
	        @Override
	        protected String doInBackground(String...  params)//执行耗时操作 
	        { 
	            //在此方法执行耗时操作,耗时操作中发布进度,更新进度条 
	            //String result = download(); 
	            for (int i = 0; i < 100; i++) 
	            { 
	                try
	                { 
	                    Thread.sleep(100); 
	                    publishProgress(i);//进度条每次更新10%,执行中创建新线程处理onProgressUpdate()
        
	                } 
	                catch (InterruptedException e) 
	                { 
	                    e.printStackTrace(); 
	                } 
	                    
	            } 
	            return "下载完成!"; 
	        } 
	            
	        @Override
	        protected void onPostExecute(String result)//执行耗时操作之后处理UI线程事件 
	        { 
	            //在此方法执行main线程操作 
	            progressBar.setVisibility(View.GONE);//下载完成后,隐藏进度条 
	            textView.setText(result); 
	        } 
	            
	    } 
	    @Override
	    protected void onCreate(Bundle savedInstanceState) 
	    { 
	        super.onCreate(savedInstanceState); 
	        setContentView(R.layout.activity_main); 
	            
	        findViewById(R.id.button1).setOnClickListener(this); 
	        textView = (TextView) findViewById(R.id.textView1); 
	        progressBar = (ProgressBar) findViewById(R.id.progressBar1); 
	    } 
	        
	    @Override
	    public void onClick(View v) 
	    { 
	        switch (v.getId()) 
	        { 
	        case R.id.button1: 
	            btnClick(); 
	            break; 
	            
	        default: 
	            break; 
	        } 
	    } 
	    private void btnClick()//创建AsyncTask对象,执行任务 
	    { 
	        MyAsyncTask asyncTask = new MyAsyncTask(); 
	        asyncTask.execute("http://www.google.com");//可以通过此处传参数给AsyncTask,execute方法只能在UI线程里使用 
	    } 
	    private String download()//下载,耗时操作 
	    { 
	        try
	        { 
	            Thread.sleep(3000); 
	        } 
	        catch (InterruptedException e) 
	        { 
	            e.printStackTrace(); 
	        } 
	        return "下载完成!"; 
	    } 
	}
 2、activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:orientation="vertical"
    tools:context="com.example.asynctask.MainActivity"
    tools:showIn="@layout/activity_main">
    
    <TextView
        android:id="@+id/textView1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="30dp"
        android:gravity="center"
        android:text="Hello World!"/>
    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/button1"
        android:text="start progressbar!!"/>

    <ProgressBar
        android:id="@+id/progressBar1"
        android:max="100"
        style="@android:style/Widget.ProgressBar.Horizontal"
        android:layout_width="fill_parent"
        android:layout_height="20dp"
        android:progress="50"
        />

</LinearLayout>
   3、AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.asynctask"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="19"
        android:targetSdkVersion="19" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>


   4、执行结果



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值