异步的轻量级实现;
AsynceTask简述:
1.功能类似于Handler,都是为了防止UI线程操作阻塞而衍生而来。
2.AsyncTask是Handler的一个轻量级实现,模型类似于IntentService于Service。都是为了更加方便操作。(因为一般的异步,我们都是开启一个子线程或是匿名线程,缺点就是样的实现对于线程的操作,控制是十分困难)
3.阐述下Handler,一般我们就认为Handler既一个Android消息处理器。默认情况下,他只接受当前线程的消息实例。
但是,当在一个多线程,比如子线程数据处理后更新Ui线程,此时只要存在Handler的指针,简单的说就是实例对象时,
消息的收发处理就能执行在不同的进程中了,这个也是我们常用到的异步处理手法。
4.从源代码中看AsyncTask类中有 线程池,同样也实例化了一个Handler对象。
说白了,AsyncTask只是对以上我们自己用handler,thread实现的异步做了一个很好的封装,使用到线程池对于线程的销毁和创建开销大大减小
综合了下:AsyncTask的异步处理相对于传统的handler+Thread组合,减少程序中线程过多开销过大。操作和管理更加方便。
AsyncTask的是实现:
和所有网上说的一样,该对象必须在UiThread中实例化,然后执行execute方法。
copy下:AsyncTask定义了三种泛型类型 Params,Progress和Result。
•Params 启动任务执行的输入参数,比如HTTP请求的URL。
•Progress 后台任务执行的百分比。
•Result 后台执行任务最终返回的结果,比如String。
AsyncTask的执行分为四个步骤,每一步都对应一个回调方法,开发者需要实现一个或几个方法。在任务的执行过程中,这些方法被自动调用。
onPreExecute(), 该方法将在执行实际的后台操作前被UI thread调用。可以在该方法中做一些准备工作,如在界面上显示一个进度条。
doInBackground(Params…), 将在onPreExecute 方法执行后马上执行,该方法运行在后台线程中。这里将主要负责执行那些很耗时的后台计算工作。可以调用 publishProgress方法来更新实时的任务进度。该方法是抽象方法,子类必须实现。
onProgressUpdate(Progress…),在publishProgress方法被调用后,UI thread将调用这个方法从而在界面上展示任务的进展情况,例如通过一个进度条进行展示。
onPostExecute(Result), 在doInBackground 执行完成后,onPostExecute 方法将被UI thread调用,后台的计算结果将通过该方法传递到UI thread.
使用AsyncTask类,以下是几条必须遵守的准则:
-
Task的实例必须在UI thread中创建
-
execute方法必须在UI thread中调用
-
不要手动的调用onPreExecute(), onPostExecute(Result),doInBackground(Params…), onProgressUpdate(Progress…)这几个方法
-
该task只能被执行一次,否则多次调用时将会出现异常
下面是我看了源代码书写下整个流程:
step 1:在UiThread中实例化类 执行了父类的构造 ( 代码都简写了)
[java] view plain copy
-
public AsyncTask() {
-
mWorker = new WorkerRunnable{//实现线程接扣的线程类。
-
public Result call() {
-
return doInBackground(mParams);//在类似于线程的run方法中调用doInBackground(mParams);
-
}
-
};
-
mFuture = new FutureTask(mWorker) {//接受mWorker线程对象,实例化FutureTask类来操作线程。
-
}
step 2 :在UiThread中调用AsyncTask对象的execute方法。
[java] view plain copy
-
public execute(){
-
onPreExecute();//此方法中先调用了onPreExecute,也就是我们上文提到的准备工作。
-
sExecutor.execute(mFuture);// 然后通过线程池操作构造中我们实例化的runnable对象。
-
return this;
step 3 :根据step 2 可以知道 程序这步执行的应该是mFuture 代码中的done()
[java] view plain copy
-
protected void done() {
-
Message message;
-
Result result = null;
-
// 发送消息Tag和 消息处理结果。消息处理结果又用AsyncTaskResult类封装起来,实例化对象传递进去的result就是上面doInBackground方法执行后的结果。
-
message = sHandler.obtainMessage(MESSAGE_POST_RESULT,
-
new AsyncTaskResult(AsyncTask.this, result));
-
message.sendToTarget();
-
}
step 4: 根据step 3,很明显 handler发送,后紧接着就是消息的处理
[java] view plain copy
-
private static class InternalHandler extends Handler {
-
@Override
-
public void handleMessage(Message msg) {
-
AsyncTaskResult result = (AsyncTaskResult) msg.obj;
-
switch (msg.what) {
-
case MESSAGE_POST_RESULT://通过step 3的Tag,执行改方法;
-
// There is only one result
-
result.mTask.finish(result.mData[0]);
-
break;
-
case MESSAGE_POST_PROGRESS:
-
result.mTask.onProgressUpdate(result.mData);
-
break;
-
case MESSAGE_POST_CANCEL:
-
result.mTask.onCancelled();
-
break;
-
}
-
}
-
}
step 5: 根据step 4执行 result.mTask.finish
[java] view plain copy
-
private void finish(Result result) {
-
if (isCancelled()) result = null;
-
onPostExecute(result);// 注意。。执行了onPostExecute
-
mStatus = Status.FINISHED;
-
}
至此我们发现上文提到
onPreExecute() ----》doInBackground()------》onPostExecute()基本流程方法都游走一边
还剩下两个刷新进度的 : onProgressUpdate()和publishProgress();
[java] view plain copy
-
protected final void publishProgress(Progress… values) {
-
sHandler.obtainMessage(MESSAGE_POST_PROGRESS,
-
new AsyncTaskResult(this, values)).sendToTarget();
-
}
从这个方法很容易看出,其实他就是一个Handler消息发送的实现。
网上一般说可以在doInBackground()调用该方法,然后再回过去看handler实例化那段代码
case MESSAGE_POST_PROGRESS:
result.mTask.onProgressUpdate(result.mData);
break;
执行了onProgressUpdate()
该类出现了FutureTask以及callable等java中的类。因为手边没有java 源码。没有细细读下
整个流程大致如上。
下面附上一个用过的,也算比较常用的首页图片异步获取例子代码:
[java] view plain copy
-
public class MainActivity extends BaseActivity implements OnClickListener {
-
private static final HashMap<String, Drawable> HOMEIMAGECACHE = new HashMap<String, Drawable>();
-
@Override
-
public void onCreate(Bundle savedInstanceState) {
-
super.onCreate(savedInstanceState);
-
mContext = MainActivity.this;
-
FrameLayout ll = (FrameLayout) this.getLayoutInflater().inflate(
-
R.layout.main, null);
-
setContentView(ll);
-
init();
-
fatchData();
-
}
-
private void fatchData() {
-
GetHomePageImageTask imageTask = new GetHomePageImageTask();
-
//首页图片获取测试
-
String imgUrl = “http://192.168.1.1/img/xxxxx.png,http://192.168.1.1/img/zuqiu2.png,http://192.168.1.1/img/zuqiu3.png”;
-
imageTask.execute(imgUrl);
-
}
-
private void init() {
-
loadView();
-
}
-
private Gallery mGallery;
-
/**
-
*
-
*/
-
private void loadView() {
-
mGallery = (Gallery) findViewById(R.id.homepage_gallery);
-
}
-
class GetHomePageImageTask extends AsyncTask<String, Integer, Drawable []>{
-
/**
-
* step 1: 在ui Thread中调用execute()后执行该方法;
-
* 一般可以做些准备工作。
-
*/
-
@Override
-
protected void onPreExecute() {
-
// TODO Auto-generated method stub
-
super.onPreExecute();
-
}
-
/**
-
* step 2: 执行后台操作;
-
*/
-
@Override
-
protected Drawable[] doInBackground(String… params) {
-
String [] imageUrls= params[0].split(“,”);
-
Drawable [] drawables = new Drawable[imageUrls.length];
-
for(int i = 0; i < imageUrls.length;i++ ){
-
drawables[i] = lookupFile(imageUrls[i]);
-
}
-
return drawables;
-
}
-
/**
-
*在publishProgress方法被调用后,ui线程将调用该方法更新进度;
-
*/
-
@Override
-
protected void onProgressUpdate(Integer… values) {
-
// TODO Auto-generated method stub
-
super.onProgressUpdate(values);
-
}
-
/**
-
* step 3:在doInBackground执行完成后i,该方法被Ui线程执行那个调用;
-
*/
-
@Override
-
protected void onPostExecute(Drawable[] result) {
-
// TODO Auto-generated method stub
-
super.onPostExecute(result);
-
ImageAdapter adapter = new ImageAdapter(mContext, result);
-
mGallery.setAdapter(adapter);
-
}
-
}
-
class ImageAdapter extends BaseAdapter {
-
Holder holder;
-
/* 声明变量 */
-
int mGalleryItemBackground;
-
private Context mContext;
-
private Drawable[] _bitmap;
-
LayoutInflater inflater;
-
/* ImageAdapter的构造器 */
-
public ImageAdapter(Context c, Drawable[] bitmap) {
-
mContext = c;
-
_bitmap = bitmap;
-
}
-
/* 覆盖的方法getCount,返回图片数目 */
-
public int getCount() {
-
return _bitmap.length;
-
}
最后
简历首选内推方式,速度快,效率高啊!然后可以在拉钩,boss,脉脉,大街上看看。简历上写道熟悉什么技术就一定要去熟悉它,不然被问到不会很尴尬!做过什么项目,即使项目体量不大,但也一定要熟悉实现原理!不是你负责的部分,也可以看看同事是怎么实现的,换你来做你会怎么做?做过什么,会什么是广度问题,取决于项目内容。但做过什么,达到怎样一个境界,这是深度问题,和个人学习能力和解决问题的态度有关了。大公司看深度,小公司看广度。大公司面试你会的,小公司面试他们用到的你会不会,也就是岗位匹配度。
选定你想去的几家公司后,先去一些小的公司练练,学习下面试技巧,总结下,也算是熟悉下面试氛围,平时和同事或者产品PK时可以讲得头头是道,思路清晰至极,到了现场真的不一样,怎么描述你所做的一切,这绝对是个学术性问题!
面试过程一定要有礼貌!即使你觉得面试官不尊重你,经常打断你的讲解,或者你觉得他不如你,问的问题缺乏专业水平,你也一定要尊重他,谁叫现在是他选择你,等你拿到offer后就是你选择他了。
金九银十面试季,跳槽季,整理面试题已经成了我多年的习惯!在这里我和身边一些朋友特意整理了一份快速进阶为Android高级工程师的系统且全面的学习资料。涵盖了Android初级——Android高级架构师进阶必备的一些学习技能。
附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
本文在开源项目:【GitHub 】中已收录,里面包含不同方向的自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…
朋友特意整理了一份快速进阶为Android高级工程师的系统且全面的学习资料。涵盖了Android初级——Android高级架构师进阶必备的一些学习技能。**
附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
[外链图片转存中…(img-r1BjrMud-1727084211537)]
本文在开源项目:【GitHub 】中已收录,里面包含不同方向的自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…