AsyncTask应用解析
当第一次启动一个Android程序时,Android会自动创建一个称为“main”主线程的线程。这个主线程(也称为UI线程)很重要,因为它负责把事件分派到相应的控件,其中就包括屏幕绘图事件,它同样是用户与Andriod控件交互的线程。比如,当你在屏幕上按下一个按钮后,UI线程会把这个事件分发给刚按得那个按钮,紧接着按钮设置它自身为被按下状态并向事件队列发送一个无效(invalidate)请求。UI线程会把这个请求移出事件队列并通知按钮在屏幕上重新绘制自身。
Android单线程模型会在没有考虑到它的影响的情况下引起Android应用程序性能低下,因为所有的任务都在同一个线程中执行,如果执行一些耗时的操作,如访问网络或查询数据库,会阻塞整个用户界面。当在执行一些耗时的操作的时候,不能及时地分发事件,包括用户界面重绘事件。从用户的角度来看,应用程序看上去像挂掉了。更糟糕的是,如果阻塞应用程序的时间过长(现在大概是5秒钟)Android会向用户提示一些信息,即打开一个“应用程序没有相应(application not responding)”的对话框。在单线程模型中始终要记住两条法则:
不要阻塞UI线程
确保只在UI线程中访问Android UI工具包
•线程无法管理,匿名线程创建并启动后就不受程序的控制了,如果有很多个请求发送,那么就会启动非常多的线程,系统将不堪重负。
•另外,前面已经看到,在新线程中更新UI还必须要引入handler,这让代码看上去非常臃肿。
•Params 启动任务执行的输入参数,比如HTTP请求的URL。
•Progress 后台任务执行的百分比。
•Result 后台执行任务最终返回的结果,比如String。
子类化AsyncTask
实现AsyncTask中定义的下面一个或几个方法
从网上获取一个网页,在一个TextView中将其源代码显示出来
- package test.list;
- import java.io.ByteArrayOutputStream;
- import java.io.InputStream;
- import java.util.ArrayList;
- import org.apache.http.HttpEntity;
- 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.app.Activity;
- import android.app.ProgressDialog;
- import android.content.Context;
- import android.content.DialogInterface;
- import android.os.AsyncTask;
- import android.os.Bundle;
- import android.os.Handler;
- import android.os.Message;
- import android.view.View;
- import android.widget.Button;
- import android.widget.EditText;
- import android.widget.TextView;
- public class NetworkActivity extends Activity{
- private TextView message;
- private Button open;
- private EditText url;
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.network);
- message= (TextView) findViewById(R.id.message);
- url= (EditText) findViewById(R.id.url);
- open= (Button) findViewById(R.id.open);
- open.setOnClickListener(new View.OnClickListener() {
- public void onClick(View arg0) {
- connect();
- }
- });
- }
- private void connect() {
- PageTask task = new PageTask(this);
- task.execute(url.getText().toString());
- }
- class PageTask extends AsyncTask<String, Integer, String> {
- // 可变长的输入参数,与AsyncTask.exucute()对应
- ProgressDialog pdialog;
- public PageTask(Context context){
- pdialog = new ProgressDialog(context, 0);
- pdialog.setButton("cancel", new DialogInterface.OnClickListener() {
- public void onClick(DialogInterface dialog, int i) {
- dialog.cancel();
- }
- });
- pdialog.setOnCancelListener(new DialogInterface.OnCancelListener() {
- public void onCancel(DialogInterface dialog) {
- finish();
- }
- });
- pdialog.setCancelable(true);
- pdialog.setMax(100);
- pdialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
- pdialog.show();
- }
- @Override
- protected String doInBackground(String... params) {
- try{
- HttpClient client = new DefaultHttpClient();
- // params[0]代表连接的url
- HttpGet get = new HttpGet(params[0]);
- HttpResponse response = client.execute(get);
- HttpEntity entity = response.getEntity();
- long length = entity.getContentLength();
- InputStream is = entity.getContent();
- String s = null;
- if(is != null) {
- ByteArrayOutputStream baos = new ByteArrayOutputStream();
- byte[] buf = new byte[128];
- int ch = -1;
- int count = 0;
- while((ch = is.read(buf)) != -1) {
- baos.write(buf, 0, ch);
- count += ch;
- if(length > 0) {
- // 如果知道响应的长度,调用publishProgress()更新进度
- publishProgress((int) ((count / (float) length) * 100));
- }
- // 让线程休眠100ms
- Thread.sleep(100);
- }
- s = new String(baos.toByteArray()); }
- // 返回结果
- return s;
- } catch(Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- @Override
- protected void onCancelled() {
- super.onCancelled();
- }
- @Override
- protected void onPostExecute(String result) {
- // 返回HTML页面的内容
- message.setText(result);
- pdialog.dismiss();
- }
- @Override
- protected void onPreExecute() {
- // 任务启动,可以在这里显示一个对话框,这里简单处理
- message.setText(R.string.task_started);
- }
- @Override
- protected void onProgressUpdate(Integer... values) {
- // 更新进度
- System.out.println(""+values[0]);
- message.setText(""+values[0]);
- pdialog.setProgress(values[0]);
- }
- }
- }
转载于:https://www.cnblogs.com/sardine/archive/2011/07/29/2121587.html
AsyncTask应用解析相关推荐
- [学习总结]7、Android AsyncTask完全解析,带你从源码的角度彻底理解
我们都知道,Android UI是线程不安全的,如果想要在子线程里进行UI操作,就需要借助Android的异步消息处理机制.之前我也写过了一篇文章从源码层面分析了Android的异步消息处理机制,感兴 ...
- AsyncTask源代码解析
快要毕业了.近期在阿里巴巴校园招聘面试,一面过了,感觉挺轻松,可能是运气好.面试官感觉比我腼腆一些.我俩从android绕到了spring mvc 到数据库悲观锁 到linux 然后又会到了andro ...
- android asynctask,Android AsyncTask原理解析
想要启动一个AsyncTask,首先需要创建一个AsyncTask对象然后调用execute方法.例如: new DownloadFilesTask().execute(); DownloadFile ...
- android asynctask 参数,Android AsyncTask 详细解析
结构 继承关系 public abstract class AsyncTask extends Object java.lang.Object android.os.AsyncTask 类概述 Asy ...
- android activity启动流程_1307页!一线大厂Android面试全套真题解析!
/ 前言 / 金九银十到了,很多读者都反映有面试的需求,所以我特地给大家准备了一点资料! 下面的题目都是大家在面试一线互联网大厂时经常遇到的面试真题和答案解析,如果大家还有其他好的题目或者好的 ...
- 【Android 异步操作】AsyncTask 异步任务 ( 参数简介 | 方法简介 | 使用方法 | AsyncTask 源码分析 )
文章目录 一.AsyncTask 参数简介 二.AsyncTask 方法简介 三.AsyncTask 基本用法 四.AsyncTask 构造函数源码解析 五.AsyncTask 构造函数相关源码注释 ...
- Android开发之异步消息处理机制AsyncTask
转自:Android AsyncTask完全解析,带你从源码的角度彻底理解 另外一篇比较详细的博文:http://blog.csdn.net/liuhe688/article/details/6532 ...
- AsyncTask异步任务
3.7 AsyncTask异步任务 分类 Android 基础入门教程 本节引言: 本节给大家带来的是Android给我们提供的一个轻量级的用于处理异步任务的类:AsyncTask,我们一般是 继承A ...
- AsyncTask原理
为什么要用AsyncTask 我们知道,Android应用的主线程(UI 线程,是线程不安全的,负责前台用户界面的绘制以及响应用户的操作)肩负着绘制用户界面和及时响应用户操作的重任,为了避免" ...
最新文章
- NMAP分布式扫描工具dnmap
- 深入Mysql,SqlServer,Oracle主键自动增长的设置详解
- boost::lockfree::queue用法的测试程序
- Struts 2基础入门
- ios中base64编码
- python二维列表做参数_python sum函数iterable参数为二维list,start参数为“[]”该如何理解...
- 有关于iphone 音频 录制 播发
- tab控件的使用心得
- 深入理解javascript中的焦点管理
- 数学:深入浅出通信原理(陈爱军)
- Delphi开发工具的使用
- NameNode故障处理之数据恢复
- 服务器管理口IP及账号密码(知识汇总)
- 幻方解法之horse法生成奇阶幻方
- sdut-3386 小雷的冰茶几
- EXCEL应用:数据可视化终极教程
- 浙大计算机学院博士毕业论文要求,浙大在读博士需要3篇SCI 论文才能毕业,清华博士却不作要求!...
- 防黑客专家-MCK CBS
- MDN和IMSI码详细解释
- The Sandbox 与 Knights of Degen 达成合作,在元宇宙建立王国