MyAsyncTask task = new MyAsyncTask();
task.execute(10);//对应类中第一个泛型Integer
}
/**
- 求和异步任务
*/
class MyAsyncTask extends AsyncTask<Integer, Integer, Long> {
/**
- 初始化任务,展示进度条,在主线程
*/
@Override
protected void onPreExecute() {
super.onPreExecute();
Log.d(TAG, "— onPreExecute — " + Thread.currentThread().getName());
mDialog = new ProgressDialog(context);//创建一个进度对话框
mDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
mDialog.show();
}
/**
-
在子线程执行耗时操作,通过publishProgress(Progress … progress)方法将任务执行的进度传出
-
@param params 该参数由task.execute(10);传递而来
-
@return
*/
@Override
protected Long doInBackground(Integer… params) {
long sum = 0;
for (int i = 1; i < params[0]; i++) {
sum += i;
publishProgress(params[0], i);//发布进度,参数将传递到onProgressUpdate方法中
try {
Thread.sleep(1000);
Log.d(TAG, "— doInBackground — " + Thread.currentThread().getName() + " i == " + i);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
return sum;
}
/**
-
执行在主线程,向用户展示任务的进度
-
@param values 该参数由publishProgress(Progress … progress)传递而来
*/
@Override
protected void onProgressUpdate(Integer… values) {
super.onProgressUpdate(values);
mDialog.setMax(values[0]);
mDialog.setProgress(values[1]);
}
/**
-
执行在主线程,任务执行完成后的操作,隐藏进度条等
-
@param aLong 该参数由doInBackground()返回
*/
@Override
protected void onPostExecute(Long aLong) {
super.onPostExecute(aLong);
//返回操作结果 , 进度对话框消失
mDialog.dismiss();
Log.d(TAG, "— onPostExecute — " + Thread.currentThread().getName() + " aLong == " + aLong);
}
}
}
这个小demo通过求1-10的和,在doInBackground()方法中通过延时的方式模拟了耗时操作,简单的演示了AsyncTask的使用。
Log日志如下:
02-17 09:40:32.214 8207-8207/com.qj.asynctasktest D/MainActivity: — onPreExecute — main
02-17 09:40:33.270 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 1
02-17 09:40:34.273 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 2
02-17 09:40:35.277 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 3
02-17 09:40:36.279 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 4
02-17 09:40:37.280 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 5
02-17 09:40:38.281 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 6
02-17 09:40:39.282 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 7
02-17 09:40:40.284 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 8
02-17 09:40:41.286 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 9
02-17 09:40:42.288 8207-8246/com.qj.asynctasktest D/MainActivity: — doInBackground — AsyncTask #1 i == 10
02-17 09:40:42.310 8207-8207/com.qj.asynctasktest D/MainActivity: — onPostExecute — main aLong == 55
由Log可看出:
onPreExecute()和onPostExecute()方法都执行在主线程,onProgressUpdate()能够更改UI(更改进度条进度)必然也是主线程。
doInBackground()方法执行在线程池某一线程中,(看过源码后得到的结果,通过Log可以知道该方法没有执行在主线程中)
最后
考虑到文章的篇幅问题,我把这些问题和答案以及我多年面试所遇到的问题和一些面试资料做成了PDF文档,如果有需要的朋友可以私信我【面试】免费领取
%9A%E8%BF%99%E4%BA%9B%EF%BC%9F%E5%A6%82%E4%BD%95%E9%9D%A2%E8%AF%95%E6%8B%BF%E9%AB%98%E8%96%AA%EF%BC%81.md)**
[外链图片转存中…(img-LN0uwwBF-1646219627993)]
[外链图片转存中…(img-nmHfkykM-1646219627994)]
喜欢的朋友可以关注、转发、点赞 感谢!