使用AsyncTask运行异步任务
2015-08-25 15:45
447 查看
AsyncTask,是Android提供的轻量级的异步类,将耗时的操作转移到后台线程,并在操作完成之后更新UI线程实现同步;
可以直接继承AsyncTask,在类中实现异步操作,并提供接口反馈当前异步执行的程度
使用场景:
生命周期较短并且需要在UI上显示进度与结果;如果生命周期较长,比如从Intent下载文件,还是使用Service组件比较合适
AsyncTask分析:
public abstract class AsyncTask<Params, Progress, Result>{}
AsyncTask定义了三种泛型类型 Params,Progress和Result。
(1)Params 启动任务执行的输入参数,比如HTTP请求的URL。主体提供给方法:
public final AsyncTask<Params, Progress, Result> execute(Params... params) {}
(2)Progress 后台任务执行的百分比。
(3)Result 后台执行任务最终返回的结果,比如String。
继承AsyncTask需要重写以下这几个方法:
(1)doInBackground(Params…values) 后台执行,比较耗时的操作都可以放在这里。注意这里不能直接操作UI。此方法在后台线程执行,完成任务的主要工作,通常需要较长的时间。
在执行过程中可以调用publishProgress(Progress…values)来更新任务的进度。
(2)onPostExecute(Result result) 相当于Handler 处理UI的方式,在这里面可以使用在doInBackground 得到的结果处理操作UI。
此方法在主线程执行,任务执行的结果作为此方法的参数返回
其他可以重写的方法:
(1)onProgressUpdate(Progress…values)
可以使用进度条增加用户体验度。 此方法在主线程执行,用于显示任务执行的进度。
(2)onPreExecute()
这里是最终用户调用Excute时的接口,当任务执行之前开始调用此方法,可以在这里显示进度对话框。
(3)onCancelled()
用户调用取消时,要做的操作
主线程调用:
增加了进度数据的登录:
可以直接继承AsyncTask,在类中实现异步操作,并提供接口反馈当前异步执行的程度
使用场景:
生命周期较短并且需要在UI上显示进度与结果;如果生命周期较长,比如从Intent下载文件,还是使用Service组件比较合适
AsyncTask分析:
public abstract class AsyncTask<Params, Progress, Result>{}
AsyncTask定义了三种泛型类型 Params,Progress和Result。
(1)Params 启动任务执行的输入参数,比如HTTP请求的URL。主体提供给方法:
public final AsyncTask<Params, Progress, Result> execute(Params... params) {}
(2)Progress 后台任务执行的百分比。
(3)Result 后台执行任务最终返回的结果,比如String。
继承AsyncTask需要重写以下这几个方法:
(1)doInBackground(Params…values) 后台执行,比较耗时的操作都可以放在这里。注意这里不能直接操作UI。此方法在后台线程执行,完成任务的主要工作,通常需要较长的时间。
在执行过程中可以调用publishProgress(Progress…values)来更新任务的进度。
(2)onPostExecute(Result result) 相当于Handler 处理UI的方式,在这里面可以使用在doInBackground 得到的结果处理操作UI。
此方法在主线程执行,任务执行的结果作为此方法的参数返回
其他可以重写的方法:
(1)onProgressUpdate(Progress…values)
可以使用进度条增加用户体验度。 此方法在主线程执行,用于显示任务执行的进度。
(2)onPreExecute()
这里是最终用户调用Excute时的接口,当任务执行之前开始调用此方法,可以在这里显示进度对话框。
(3)onCancelled()
用户调用取消时,要做的操作
public class UserLoginTask extends AsyncTask<Void, Void, Boolean> { private final String mLoginName; private final String mPassword; UserLoginTask(String loginName, String password) { mLoginName = loginName; mPassword = password; } @Override protected Boolean doInBackground(Void... params) { try { //登录 boolean result=fn_login(); if (result == true) { //保存缓存 SharedPreferences sp = getSharedPreferences("setting", Context.MODE_PRIVATE); SharedPreferences.Editor editor = sp.edit(); editor.putString("ServerIP", mServerIPView.getText().toString()); editor.putString("LoginName", mLoginNameView.getText().toString()); editor.apply(); return true; } } catch (Exception e) { Log.e(LoginActivity.class.toString(), e.getMessage()); return false; } return false; } @Override protected void onPostExecute(final Boolean success) { showProgress(false); if (success) { Toast.makeText(LoginActivity.this, "登陆成功,跳转页面", Toast.LENGTH_SHORT).show(); //finish(); } else { mPasswordView.setError(getString(R.string.error_incorrect_password)); mPasswordView.requestFocus(); } } @Override protected void onCancelled() { showProgress(false); } }
主线程调用:
public void showProgress(final boolean show) { mProgressView.setVisibility(show ? View.VISIBLE : View.GONE); mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE); } btnLogin.setOnClickListener(new OnClickListener() { @Override public void onClick(View view) { showProgress(true); UserLoginTask mAuthTask = new UserLoginTask(loginName, password); mAuthTask.execute((Void) null); } });
增加了进度数据的登录:
public class UserLoginTask extends AsyncTask<Integer, Integer, Boolean> { private final String mLoginName; private final String mPassword; private final ProgressBar mProgressBar; UserLoginTask(String loginName, String password, ProgressBar progressBar) { mLoginName = loginName; mPassword = password; mProgressBar = progressBar; } /** * 这里的Integer参数对应AsyncTask中的第一个参数 * 这里的String返回值对应AsyncTask的第三个参数 * 该方法并不运行在UI线程当中,主要用于异步操作,所有在该方法中不能对UI当中的空间进行设置和修改 * 但是可以调用publishProgress方法触发onProgressUpdate对UI进行操作 */ @Override protected Boolean doInBackground(Integer... params) { try { int i = 0; for (i = 1; i <= 100; i++) { Thread.sleep(1000); publishProgress(i); } return true; } catch (Exception e) { e.printStackTrace(); } return false; } /** * 这里的String参数对应AsyncTask中的第三个参数(也就是接收doInBackground的返回值) * 在doInBackground方法执行结束之后在运行,并且运行在UI线程当中 可以对UI空间进行设置 */ @Override protected void onPostExecute(Boolean result) { mProgressBar.setVisibility(View.INVISIBLE); if (result) { Toast.makeText(LoginActivity.this, "登陆成功,跳转页面", Toast.LENGTH_SHORT).show(); //finish(); } else { Toast.makeText(LoginActivity.this, "登陆失败", Toast.LENGTH_SHORT).show(); } } //该方法运行在UI线程当中,并且运行在UI线程当中 可以对UI空间进行设置 @Override protected void onPreExecute() { mProgressBar.setVisibility(View.VISIBLE); } @Override protected void onCancelled() { mProgressBar.setVisibility(View.INVISIBLE); } /** * 这里的Integer参数对应AsyncTask中的第二个参数 * 在doInBackground方法当中,,每次调用publishProgress方法都会触发onProgressUpdate执行 * onProgressUpdate是在UI线程中执行,所有可以对UI空间进行操作 */ @Override protected void onProgressUpdate(Integer... values) { int value = values[0]; mProgressBar.setProgress(value); } }
相关文章推荐
- 进程使用的内存空间分布情况
- 安装google的gtest库
- HTML源码中 form 标签的 enctype 属性
- Repository 返回 IQueryable?还是 IEnumerable?
- 命令行下设置串口并发送
- 衡量算法的效率
- Error:无法打开 源文件 “stdafx.h”
- win7设置电脑保护眼睛颜色(终极方法,提供两种颜色选择)
- mysql版本分类
- java中instanceof用法
- baseDao的用法
- 虚拟内存管理的作用/好处
- jquery学习笔记-----插件的编写
- Geohash的原理、算法和具体应用探究(优秀)
- Mysql 主从复制
- 【POJ1733】【Parity game】【map离散化】【加权并查集模板】
- 如何在window下操作和连接sqlite 的db文件
- C#中Datatable的Compute的用法(转载)
- Winform 打印面单
- jquery学习笔记-----ajax