`

AsyncTask简单小用法总结

阅读更多
AsyncTack:

概述: AsyncTask是在Android SDK 1.5之后推出的一个方便编写后台线程与UI线程交互的辅助类。AsyncTask的内部实现是一个线程池,每个后台任务会提交到线程池中的线程执行,然后使用Thread+Handler的方式调用回调函数。


AsyncTask的构造函数有三个模板参数:
1.Params,传递给后台任务的参数类型。
2.Progress,后台计算执行过程中,进步单位(progress units)的类型。(就是后台程序已经执行了百分之几了。)
3.Result, 后台执行返回的结果的类型。
AsyncTask并不总是需要使用上面的全部3种类型。标识不使用的类型很简单,只需要使用Void类型即可。


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()方法时调用

演示Demo:
运行效果图:
[img]

[/img]
[img]

[/img]

工具类AsyncTaskUtil:
package com.amaker.asynctasktest;

import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import android.R.integer;
import android.app.ProgressDialog;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.AsyncTask;
/**
 * 异步获取图片简单工具类
 * 传入url,返回一张图片
 * @author blacktiger
 *
 */
public abstract class AsyncTaskUtil extends AsyncTask<String, integer, Bitmap> {
	private ProgressDialog mdialog;
	private Context mcontext;
	
	public AsyncTaskUtil(Context context){
		mcontext = context;
	}
	
	// doInBackground(Params...)之前被调用,在ui线程执行
	protected void onPreExecute() {
		mdialog = new ProgressDialog(mcontext);
		mdialog.setTitle("请稍等");
		mdialog.setMessage("正在加载...");
		mdialog.show();
		super.onPreExecute();
	}
	
	// 处理后台执行的任务,在后台线程执行
	protected Bitmap doInBackground(String... params) {
		Bitmap bm;
		try {
			HttpClient hc = new DefaultHttpClient();
			HttpGet hg = new HttpGet(params[0]);
			HttpResponse hr = hc.execute(hg);
			bm = BitmapFactory.decodeStream(hr.getEntity().getContent());
		} catch (Exception e) {
			return null;
		}
		return bm;
	}
	
	// 在调用publishProgress之后被调用,在ui线程执行
	protected void onProgressUpdate(integer... values) {
		super.onProgressUpdate(values);
	}
	
	// 后台任务执行完之后被调用,在ui线程执行
	protected void onPostExecute(Bitmap result) {
		mdialog.dismiss();
		refreshUI(result);
		super.onPostExecute(result);
	}
	
	// 在ui线程执行
	protected void onCancelled() {
		mdialog.dismiss();
		super.onCancelled();
	}
	
	public abstract void refreshUI(Bitmap bm);
}


MainActivity:
package com.amaker.asynctasktest;
import android.app.Activity;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;

public class MainActivity extends Activity {
	//csdn的logo图片
    private String url = "http://csdnimg.cn/www/images/csdnindex_logo.gif";
    private ImageView mImageView;
	private Button mButton;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        mImageView = (ImageView) findViewById(R.id.imageView);
		mButton = (Button) findViewById(R.id.button);
		mButton.setOnClickListener(new OnClickListener() {

			@Override
			public void onClick(View v) {
				new AsyncTaskUtil(MainActivity.this) {
					@Override
					public void refreshUI(Bitmap bm) {
						mImageView.setImageBitmap(bm);
					}
				}.execute(url);
			}
		});
    }
}


main.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
	xmlns:android="http://schemas.android.com/apk/res/android"
	android:orientation="vertical"
	android:layout_width="fill_parent"
	android:layout_height="fill_parent">
	<Button
		android:id="@+id/button"
		android:text="下载图片"
		android:layout_width="wrap_content"
		android:layout_height="wrap_content" />
	<ImageView
		android:id="@+id/imageView"
		android:layout_height="wrap_content"
		android:layout_width="wrap_content" />
</LinearLayout>


AndroidManifest.xml配置文件:
记得添加联网权限!!!!
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.amaker.asynctasktest"
      android:versionCode="1"
      android:versionName="1.0">
    <uses-sdk android:minSdkVersion="10" />

    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <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>
     <uses-permission android:name="android.permission.INTERNET"></uses-permission> 
</manifest>
  • 大小: 13.7 KB
  • 大小: 12.5 KB
分享到:
评论

相关推荐

    Android中异步类AsyncTask用法总结

    总之,AsyncTask 是 Android 开发中处理短时、简单异步任务的得力助手,它简化了多线程与 UI 更新的同步问题,但不适用于所有异步场景。正确理解和使用 AsyncTask,可以帮助开发者更高效地构建用户界面,提升用户...

    Android中AsyncTask与handler用法实例分析

    总结来说,AsyncTask适用于简单快速的后台操作,而Handler+Message更适合需要频繁通信或者长时间运行的异步任务。选择哪种方式取决于具体的需求和任务的复杂性。在Android开发中,合理使用这两种机制可以有效地提升...

    Hanlder、HandlerThread、AsyncTask处理机制的相关Demo代码

    总结来说,`Handler`适用于处理不同线程间的消息传递,`HandlerThread`则为后台任务提供了一个可管理的消息循环环境,而`AsyncTask`是快速实现简单异步任务的好帮手。在实际开发中,开发者应根据需求选择合适的工具...

    Android AsyncTask源码分析

    首先,我们来看AsyncTask的基本用法。AsyncTask有三个泛型参数:Params(参数类型),Progress(进度类型)和Result(结果类型)。要使用AsyncTask,你需要创建一个继承自AsyncTask的子类,并重写以下关键方法: 1....

    Android中Interface 在Listview的小用法

    以下是一个简单的接口定义示例: ```java public interface OnDataLoadListener { void onDataLoaded(List, Object&gt;&gt; data); } ``` 接着,我们将使用`List, Object&gt;&gt;`作为ListView的数据源。这样的好处是灵活性高...

    android ProgressBar 全部的用法

    ProgressBar提供了多种样式和用法,适用于不同的界面需求。本文将详细介绍Android ProgressBar的使用方法,帮助开发者更好地理解和应用这一组件。 一、ProgressBar的基本类型 1. 横向进度条:默认样式,显示为一条...

    线程,线程池与Handler的用法

    相比之下,`AsyncTask`更适合简单的小型异步任务,但它已不再推荐用于新项目,因为其存在内存泄漏的风险。 线程池的概念是为了更有效地管理和控制线程资源。在Java中,我们可以使用`ExecutorService`和`...

    异步任务类的使用

    以下是一个简单的使用AsyncTask下载文件的例子: ```java public class DownloadTask extends AsyncTask, Integer, Boolean&gt; { @Override protected void onPreExecute() { // 显示进度对话框 } @Override ...

    子线程中更新UI线程的三种方法

    总结来说,子线程中更新UI线程主要有Handler+Looper、Runnable+runOnUiThread以及AsyncTask这三种方式。Handler提供了更灵活的消息机制,适合复杂的同步需求;Runnable+runOnUiThread则更为简洁,适合快速实现简单的...

    最简单常用的网络加载框

    描述中的"代码简单易懂,用法简单,一句话调用"强调了这个网络加载框的易用性。对于开发者来说,这意味着他们可以快速集成这个功能,而无需花费大量时间在理解复杂的API或实现细节上。这通常是通过提供简洁的API调用...

    Android多线程下载实现方案

    不过,这里简单介绍一下`AsyncTask`的用法: ```java public class DownloadTask extends AsyncTask, Integer, Boolean&gt; { private String url; private Context context; public DownloadTask(String url, ...

    Android--开发-- 面试题 安卓巴士总结.rar

    - AsyncTask:简单异步任务执行。 - 线程池:ThreadPoolExecutor的使用和参数配置。 6. **服务(Service)**: - 后台服务的启动方式,生命周期及特点。 - IntentService:单线程执行任务的Service,自动管理生命...

    AsyncDemo.zip

    总结起来,`@Async`是Spring Boot中实现异步任务的关键工具,通过合理配置和使用,可以显著提升应用的并发处理能力,优化系统性能。在这个`AsyncDemo`中,我们可以看到如何设置和使用`@Async`,以及如何在实际场景中...

    智能家居系统 handler-教案.doc

    6. **课堂小结**:强调Handler的特点(如消息队列、回调处理)及其在实际项目中的作用,指出根据项目需求设计思路的重要性,以及在Android中正确使用Handler更新UI的难点。 通过这个教案,学生不仅能掌握Handler的...

    android handler和线程的简单实例

    在Android开发中,`Handler`、`Message`和线程是三个非常重要的...在实际开发中,你可能会遇到更复杂的情况,例如使用`Looper`来管理消息队列,或者使用`HandlerThread`等,但这个简单的实例已经揭示了它们的基本用法。

    Android应用源码之ProgressDialogSample.zip

    总结起来,`ProgressDialogSample.zip`源码示例旨在展示如何在Android应用中使用ProgressDialog,以及如何处理其生命周期和集成到异步任务中。学习这个样本可以帮助开发者更好地理解和使用这个组件,从而提升用户...

    电子书:Android常用的方法实例代码总结(PDF文档)

    这篇电子书《Android常用的方法实例代码总结》是针对Android开发者的一份宝贵资源,它涵盖了Android开发中的关键知识点和实用技巧,旨在帮助开发者更好地理解和运用Android SDK中的各种方法。以下是书中可能涉及的...

    Android 学习(13)ProgressBar

    总结,Android的ProgressBar是一个强大且灵活的组件,无论是在简单的进度显示,还是在复杂的交互设计中,都能发挥重要作用。理解其基本使用和高级特性,对于提升Android应用的用户体验至关重要。通过不断的实践和...

    Android回调函数的例子

    本示例将深入探讨Java回调函数,并通过一个Android小程序来展示其用法。 首先,理解Java回调函数的基础概念。回调函数本质上是将一个函数作为参数传递给另一个函数,待特定条件满足或特定事件发生时,被调用的函数...

Global site tag (gtag.js) - Google Analytics