AsyncTask,是android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操作,并提供接口反馈当前异步执行的程度(可以通过接口实现UI进度更新),最后反馈执行的结果给UI主线程.
1. Android异步任务处理(AsyncTask使用):
(1)工程一览图:
(2) 首先设计布局文件activity_main.xml,如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="com.himi.asynctask.MainActivity" > <Button
android:id="@+id/read"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Button" /> <ScrollView
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/hello_world" />
</ScrollView> </LinearLayout>
布局文件效果,如下:
(3)MainActivity.java:
package com.himi.asynctask; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection; import android.app.Activity;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.TextView;
import android.widget.Toast; public class MainActivity extends Activity {
TextView text; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
text = (TextView) findViewById(R.id.textView1);
findViewById(R.id.read).setOnClickListener(new OnClickListener() { public void onClick(View v) {
ReadURL("http://www.baidu.com"); }
});;
} public void ReadURL(String url) {
/**
* AsyncTask的三个参数如下:
* Params 启动任务执行的输入参数,比如HTTP请求的URL。
* Progress 后台任务执行的百分比。
* Result 后台执行任务最终返回的结果,比如String。
*/
new AsyncTask<String, Float, String>() { /**
* doInBackground()方法用于在执行异步任务,不可以更改主线程中UI
*/
@Override
protected String doInBackground(String... params) {
try {
URL url = new URL(params[0]);
URLConnection connection = url.openConnection();
long total = connection.getContentLength(); InputStream iStream = connection.getInputStream();
InputStreamReader isr = new InputStreamReader(iStream);
BufferedReader br = new BufferedReader(isr); String line;
StringBuilder builder = new StringBuilder();
while((line = br.readLine()) != null) {
builder.append(line);
publishProgress((float)builder.toString().length()/total);
} br.close();
iStream.close(); return builder.toString();
} catch (MalformedURLException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (IOException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
return null;
} /**
* 执行任务之前调用的代码,一般用来在执行后台任务时候,对前台的提示标记
*/
@Override
protected void onPreExecute() {
Toast.makeText(MainActivity.this, "开始读取", Toast.LENGTH_LONG).show();
super.onPreExecute();
} /**onPostExecute()方法用于异步任务执行完成后,在主线程中执行的操作
**参数result是doInBackground()方法的返回值
*/
@Override
protected void onPostExecute(String result) {
text.setText(result);
super.onPostExecute(result);
} /**
* onProgressUpdate()方法用于更新异步执行中,在主线程中处理异步任务的执行信息
* 主要是告诉用户任务执行的进度,和用户进行交互.
* 这里的数组values对应于AsyncTask中的第2个参数
*
*/
@Override
protected void onProgressUpdate(Float... values) {
System.err.println(values[0]);
super.onProgressUpdate(values);
} /**
* onCancelled()方法用于异步任务被取消时,在主线程中执行相关的操作
*
*/
@Override
protected void onCancelled(String result) {
// TODO 自动生成的方法存根
super.onCancelled(result);
} @Override
protected void onCancelled() {
// TODO 自动生成的方法存根
super.onCancelled();
} }.execute(url);
} }
(4)AndroidManifest.xml:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.himi.asynctask"
android:versionCode="1"
android:versionName="1.0" > <uses-sdk
android:minSdkVersion="15"
android:targetSdkVersion="17" />
<uses-permission android:name="android.permission.INTERNET"/> <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>
运行效果,如下: