AsyncTask官方学习
异步任务学习
这两天使用到特别多的AsyncTask类,一块来学习一下吧
AsyncTask允许更方便和简单使用UI线程,这个类允许你在UI线程中进行后台操作和展示结果,而无需操作Thread或者handlers
AsyncTask是围绕Thread和Handler设计的辅助类,并不构成通用线程框架。AsyncTask最适合的场景是短时间操作(最好几秒钟),如果你需要保持长时间的运行,建议你使用java.util.concurrent包提供的API,比如Executor,ThreadPoolExecutor和FutureTask
一个异步任务是由三个泛型参数(Params,Progress,result)和四个步骤(onPreExecute,doInBackgroud,onProgressUpdate,onPostExecute)组成
最简单的使用时必须重写(doInBackgroud(Params...))和最常重写(onPostExecute)方法,比如如下例子
private class DownloadFilesTask extends AsyncTask<URL,Integer,Long>{
protected Long doInBackground(URL... urls){
int count = urls.length;
long totalSize = 0;
for(int i = 0; i< count;i++){
totalSize += Downloader.downloadFile(urls[i]);
publicProgress((i/(float)count)*100));
//如果cancel调用的话提前退出
if(isCancelled()) break;
}
return totalSize;
}
protected void onProgressUpdate(Integer... progress){
setProgressPercent(progress[0]);
}
protected void onPostExecute(Long result){
showDialog("Downloaded"+result+" bytes");
}
}
调用也非常简单
new DownloadFilesTask().execute(url1,url2,url3);
AsyncTask的三个泛型参数
Params
代表衣服任务的执行参数,需要传到doInBackground里面的参数
Progress
后台任务执行的进度单位,可以放在进度条中
Result
任务执行完成返回的结果。在onPostExecute的参数就是
三个参数不是必须要有的,也可以
private class MyTask extends AsyncTask<Void,Void,Void>{...}
AsyncTask的四个步骤
onPreExecute()在任务执行前被UI线程调用。通常被用来进行任务的一些设置,比如在用户界面显示一个进度条
doInBackground(Params...)在onPreExecute()结束后被后台线程调用,这个步骤被用来放置实际的任务,前面提到的
Params参数被传递到这里。前面提到的result参数必须在此步骤中返回,并且传递到最后一步。这里也可以使用publicProgress(Progress...)通知执行的进度。onProgressUpdate(Progress...)方法在执行
publishProgress(Progress...)之后被UI线程调用。这一步可以在用户界面显示任务执行的进度。例如这里通常显示一个进度条或者打印日志字段onPostExecute(Result)在后台任务完成之后被UI线程调用,后台的结果
result参数传递到这个方法中
取消任务
可以通过调用cancel(boolean)方法取消任务,调用之后isCancelled()会返回True。在调用此方法之后,onPostExecute(object)将不再执行,取而代之的是onCancelled(object)。为了确保任务趋势被取消了,你应该在doInBackground(object[])始终检查isCancelled()的值。
一些规则
有一些规则是需要被遵守
AsynacTask类必须在UI线程中加载- 任务(task)实例必须在UI线程中被创建
- execute()方法必须被UI线程调用
- 不要手动调用
onPreExecute()、onPostExecute(result)、doInBackground(Params...),onProgressUpdate(Progress...) - 任务只能被执行一次
具体的参数意义请参见官方文档
AsyncTask官方学习的更多相关文章
- .Net 官方学习文档
.Net 官方学习文档:https://docs.microsoft.com/zh-cn/dotnet/articles/welcome
- 《CWNA官方学习指南(第3版):认证无线网络管理员PW0-105》
<CWNA官方学习指南(第3版):认证无线网络管理员PW0-105> 基本信息 原书名:CWNA: Certified Wireless Network Administrator Off ...
- 【声明】前方不设坑位,不收费!~ 我为NET狂官方学习计划
发个通知,过段时间学习计划相关的东西就出来了,上次写了篇指引文章后有些好奇心颇重的人跟我说:“发现最近群知识库和技能库更新的频率有点大,这是要放大招的节奏啊!” 很多想学习却不知道如何规划的人想要一个 ...
- json官方学习档案
项目经常用json开发,但说实话,对json了解的一直不深入.今天看了下json的官方资料,明了很多. json官方网址:http://www.json.org/json-zh.html JSON(J ...
- AsyncTask的学习
具体的用法请看我之前的一篇随笔,用php+mysql+json实现用户反馈. AsyncTask的目标是为你的线程提供管理服务. AsyncTask的执行分为四个步骤,每一步都对应一个回调方法,这些方 ...
- AsyncTask机制学习
其内容可以参考http://blog.csdn.net/webgeek/article/details/17298237 ,首先创建一个AsyncTask类 class GetFaceDetectTa ...
- AsyncTask官方教程-推荐用AsyncTask少用Thread
Using AsyncTask AsyncTask allows you to perform asynchronous work on your user interface. It perform ...
- microsoft 官方学习资源
https://devblogs.microsoft.com/dotnet/ :_NET Blog https://docs.microsoft.com/zh-cn/learn/ :Microsof ...
- JQuery官方学习资料(译):使用JQuery的.index()方法
.index()是一个JQuery对象方法,一般用于搜索JQuery对象上一个给定的元素.该方法有四种不同的函数签名,接下来将讲解这四种函数签名的具体用法. 无参数的.index() < ...
随机推荐
- 解决ajax跨域请求 (总结)
ajax跨域请求,目前已用几种方法实现: 1)用原生js的xhr对象实现. var url="http://freegeoip.net/json/" ...
- 1Z0-053 争议题目解析134
1Z0-053 争议题目解析134 考试科目:1Z0-053 题库版本:V13.02 题库中原题为: 134.You are managing an Oracle Database 11g datab ...
- Tools - Get technical information from the Internet
Official Sites Overview / QuickStart Guide / Docs / E-books Community / Fourm / Blog Demo / Download ...
- ManagementClass类解析和C#如何获取硬件的相关信息
在.NET的项目中,有时候需要获取计算机的硬件的相关信息,在C#语言中需要利用ManagementClass这个类来进行相关操作. 现在先来介绍一下ManagementClass类,首先看一下类的继承 ...
- jQuery-1.9.1源码分析系列(十五) 动画处理
首先需要有队列(queue)的基本知识.见上一章. a.动画入口jQuery.fn.animate函数执行流程详解 先根据参数调用jQuery.speed获取动画相关参数,得到一个类似如下的对象:并且 ...
- Net设计模式实例之原型模式( Prototype Pattern)
一.原型模式简介(Brief Introduction) 原型模式(Prototype Pattern):用原型实例指定创建对象的种类,并通过拷贝这些原型创建新的对象. Specify the kin ...
- sql server实现自定义分割月功能
本文目录列表: 1.为何出现自定义分割月需求 2.sql server实现自定义分割月功能 3.测试验证效果 4.总结语 5.参考清单列表 1.为何出现自定义分割月的需求 今天梳理一个平台的所 ...
- MVC学习系列11---验证系列之客户端验证
前面学习了,服务端验证,这篇文章中,我们接着学习客户端验证,客户端的验证,使用Jquery和Jquery插件来实现[jquery.validate.min.js and jquery.validate ...
- Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://localhost:9001/api/size/get. (Reason: CORS header 'Access-Control-Allow-Origin' missing).
Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http:/ ...
- compilation与编译
关于本配置节的内容不算多,但关于ASP.NET编译的内容还是有一点的,鄙人认为只是了解一下即可,主要影响到部署. 在 App_Code 文件夹中使用多种编程语言 因为 App_Code 文件夹中的源代 ...