从AsyTask函数式封装到lambda表达式
Android官方有段介绍
https://developer.android.com/reference/android/os/AsyncTask.html
AsyncTask enables proper and easy use of the UI thread. This class allows you to perform background operations and publish results on the UI thread without having to manipulate threads and/or handlers.
大概意思是AsyncTask允许更容易地使用UI线程。此类可以在无需操作线程的情况下操作UI线程。
随着Android的发展现在AsyncTask基本已成过去式了。今天的主角并不是AsncTask,仅仅通过官方这一类来讲解一种封装思路。希望通过这一思路抛砖引玉。
首先我们编写一个工具类
AsyncTaskUtils.javapublic class AsyncTaskUtils { public static void doAsync(final IDataCallBack callBack) { new AsyncTask() { protected void onPreExecute() { callBack.onTaskBefore(); }; @Override protected T doInBackground(Void... params) { // TODO return callBack.onTasking(params); } protected void onPostExecute(T result) { callBack.onTaskAfter(result); }; }.execute(); }}
这个工具类有一个泛型T也就是当AsyncTask后台执行完后返回回来的对象,这里我们使用的是接口回调的方式,工具类doAsync(final IDataCallBack
接着我们编写回调的接口对象
public interface IDataCallBack { /**任务执行之前*/ void onTaskBefore(); /**任务执行中...*/ T onTasking(Void... params); /**任务执行之后*/ void onTaskAfter(T result);}
如上图所示,接口对应上述对AsyncTask的封装的三个方法编写了三个方法,onTaskBefore()、Tasking(Void... params)、onTaskAfter(T result)。用于上述方法的回调。
这样我们基本完成了对AsyncTask的封装。
看我们调用的地方
AsyncTaskUtils.doAsync(new IDataCallBack() { @Override public void onTaskBefore() { } @Override public String onTasking(Void... params) { } @Override public void onTaskAfter(String result) { } });
我们对比之前的方式,在没封装之前我们每次都得new一个AsyncTask对象或者extend继承这一类来做操作。细心的同学可能会发现说到底你仅仅只是封装了一层根本就没简便操作啊。是的。看下面。看我们的BaseActivity
BaseActivity.javapublic class BaseActivity extends Activity { public void doAsync(IDataCallBack callBack) { AsyncTaskUtils.doAsync(callBack); }}
调用的地方
MainActivity.this.doAsync(new IDataCallBack() { @Override public void onTaskBefore() { } @Override public String onTasking(Void... params) { String result = ""; try { DefaultHttpClient httpClient = new DefaultHttpClient(); HttpGet get = new HttpGet("http://www.baidu.com"); HttpResponse response = httpClient.execute(get); if (response.getStatusLine().getStatusCode() == 200) { result = EntityUtils.toString(response.getEntity()); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } return result; } @Override public void onTaskAfter(String result) { System.out.println(result); } });
上面只是调用的地方。这样一来我们所有的网络都统一到一个地方了。这也就是为什么在上面我把 AsyncTask
lambda表达式
接下来是我们的主角,lambda表达式。Lambda表达式是Java SE 8中引入的一个重要的新特性。lambda表达式允许你通过表达式来代替功能接口。
官方链接:http://www.developer.com/java/start-using-java-lambda-expressions.html
以前我们我们在给View设置点击事件的时候代码是这样的。
view.setOnClickListener(new OnClickListener() { @Override public void click(View view) { //方法内容 }})
而当我们在使用了lambda表达式后点击事件可以这样写。
view.setOnclickListener(view->{//方法内容});
是不是很简单。在Android Studio2.2之前虽然jdk可以使用jdk8但是对lambda却支持不是很好,当然可以引入RetroLambda Plugin来支持。随着Android Studio2.1的发布google官方终于原生支持lambda了。
不可否认使用lambda表达式使我们的代码更加简洁了,但也有人说使用了lambda表达式使我们的代码可读性降低了。
话说回来,lambda表达式作为一个新的事物。在大家都未接受的时候肯定认可他的人觉得好用漂亮。而不认可的人或者是没有入门的人觉得不好用,还看不懂就想当年Window Xp刚出来的时候大家都觉得Window 2000才是王道,XP系统那么花哨好看不好用。甚至有人还把XP的主题给换回98那种样式。扯远了。正是因为有人觉得这种new Interface的方式不好用。所以才会有lambda这种新的事物出来。lambda表达式最早是出现在Scala语言中。他允许通过函数式的方式来调用方法。可能因为Oracle官方发现了这一简便性,所以才有了jdk8中的lambda表达式。相信在不久的将来lambda表达式会变得越来越流行,肯定会有越来越多的人使用这一表达式。尤其搭配上当下热门的RxJava、Retrofit等技术。
上面的函数式封装的Demo在这里:https://github.com/Loofer/AsyncTaskFunctional
更多相关文章
- 浅谈Java中Collections.sort对List排序的两种方法
- Python list sort方法的具体使用
- python list.sort()根据多个关键字排序的方法实现
- 分享一个两个Android(安卓)scrollView同时滚动的方法
- Android(安卓)常用的画图方法
- android使用keystore打包错误解决方法
- android两次点击返回键退出和按钮退出对话框
- Android(安卓)Exception异常汇集【不定时更新】
- android volley 上传文件