rxjava等系列产品.思想是很好的,但是被大多数人用成了一坨屎!
就拿rx最经典的那个例子来说:
假设有这样一个需求:界面上有一个自定义的视图 imageCollectorView
,它的作用是显示多张图片,并能使用 addImage(Bitmap)
方法来任意增加显示的图片。现在需要程序将一个给出的目录数组 File[] folders
中每个目录下的 png 图片都加载出来并显示在imageCollectorView
中。需要注意的是,由于读取图片的这一过程较为耗时,需要放在后台执行,而图片的显示则必须在 UI 线程执行。常用的实现方式有多种,我这里贴出其中一种:
new Thread() { @Override public void run() { super.run(); for (File folder : folders) { File[] files = folder.listFiles(); for (File file : files) { if (file.getName().endsWith(".png")) { final Bitmap bitmap = getBitmapFromFile(file); getActivity().runOnUiThread(new Runnable() { @Override public void run() { imageCollectorView.addImage(bitmap); } }); } } } } }.start();
猛一看有点繁琐,应该可以优化下,别急先看看rx怎么实现.
rxjava :
Observable.from(folders) .flatMap(new Func1<File, Observable<File>>() { @Override public Observable<File> call(File file) { return Observable.from(file.listFiles()); } }) .filter(new Func1<File, Boolean>() { @Override public Boolean call(File file) { return file.getName().endsWith(".png"); } }) .map(new Func1<File, Bitmap>() { @Override public Bitmap call(File file) { return getBitmapFromFile(file); } }) .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(new Action1<Bitmap>() { @Override public void call(Bitmap bitmap) { imageCollectorView.addImage(bitmap); } });
猛一看mdzz(玛德制杖),仔细一看mdzzz(玛德真制杖)----> 代码写成这样不脑残么?知不知道什么叫做解耦合啊?
我的实现:
//----------开始加载所有图片 public void addAllImg(){ x.task().run(new Runnable() {//我用xutils3异步任务 @Override public void run() { for (File folder : folders) { //遍历文件夹 File[] files = folder.listFiles(); for (File file : files) { //遍历文件 addAllImg_1(file); //调用后续方法处理 } } } }); } private void addAllImg_1(File file){ //处理,更新ui等 if (file.getName().endsWith(".png")) { final Bitmap bitmap = getBitmapFromFile(file); getActivity().runOnUiThread(new Runnable() { @Override public void run() { imageCollectorView.addImage(bitmap); } }); } }
//----------加载所有图片完毕
rx系列缺点太多了,任意一条都够理由不用他了 因为有更好的实现呀
1.过度使用设计模式,逻辑是只有一条但是代码被你们写成了屎呀 还链式也是醉人
什么叫链式,看我的实现... 支持继续扩展 2 3 4 5 6 ... n
private void addAllImg_2()
private void addAllImg_3()
...
2.好的思想不懂合理利用,看看Android-LessCallBack是怎么用的
//按id顺序执行的
public class Test2 { @TaskFlow(thread = true, id = 0) public void doTask1() { System.out.println(Thread.currentThread().getName()+":"+"任务1"); waitTime(); } @TaskFlow(thread = false, id = 1) public void doTask1Finish() { System.out.println(Thread.currentThread().getName()+":"+"任务1执行结束"); } @TaskFlow(thread = true, id = 2) public void doTask2() { System.out.println(Thread.currentThread().getName()+":"+"任务2"); waitTime(); } @TaskFlow(thread = false, id = 3) public void doTask2Finish() { System.out.println(Thread.currentThread().getName()+":"+"任务2执行结束"); } public static void main(String[] args) { TaskFlowUtils.inject(new Test2()).run();; } public static void waitTime(){ int x = new Random().nextInt(1000) + 500; try { System.out.println("等待"+x+"毫秒"); Thread.sleep(x); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
线程:任务1 等待515毫秒 ui线程:任务1执行结束 线程:任务2 等待655毫秒 ui线程:任务2执行结束
在我看来其与rx类似,都用到next这一思想,不同的是:
lesscallback 实现复杂,调用简单
rx实现复杂,调用也特么复杂
3.耦合度太大导致调试困难的问题...满眼的next subscribe observe
有写问题写时候,你可能没发现 维护时候你就懂了
4.学习难度大,想要吃个牛肉串你让我先学宰牛?
5.少用interface 如果可以,尽量不要用 (interface是一种挖洞行为,除非不可避免否则不要挖洞)
对于你们那些 网络请求还先写个interface的我表示无法理解 每个页面都有自己的功能,在各自的页面(函数里)实现自己的功能 更是一种分布式的思想
随便搜一下都是rx怎么怎么好,支持什么什么 可以扩展什么什么 巴拉巴拉... 真正有自己的理解的有几个?
一群小菜比
大道至简,如果理解深刻,用起来会非常简单,搞出来那么复杂的东西 只说明你们理解不太深刻.