美文网首页
多任务同时进行

多任务同时进行

作者: 搬砖的小蜗牛 | 来源:发表于2017-07-12 11:39 被阅读7次

多任务同时进行

问题:如果有一个对数据进行权限检查的操作,可能有1万条、10万条等等,只写一个任务执行它会花费很多时间,这时可以考虑分成多个任务把数据分成多段同时进行?

代码如下:

public abstract class ParallelTask {
    private final static String TAG = "ParallelTask";

    public ParallelTask() {
    }


    public void preExecute(Object... args) {
    }

    public abstract void async1(); //必须实现

    public void async2() {
    }

    public void async3() {
    }

    public void async4() {
    }

    public void async5() {
    }

    public void async6() {
    }

    public void async7() {
    }

    public void async8() {
    }

    public void onAllExecute() {
    }

    public void onUICompleted() { //全部任务执行完成后会执行该方法
    }

    private Observable uiObs;

    /**
     * 执行并行任务,结束后切换到UI线程
     */
    final public void execute(Object...args) {
        preExecute(args);
        //最外层,执行UI线程
        uiObs = Observable.just(null).subscribeOn(AndroidSchedulers.mainThread());
        List<String> methods = getOverrideMethods();
        int size = methods.size();
        String[] ms = methods.toArray(new String[size]);
        getParallelObservable(ms)
                .observeOn(Schedulers.immediate())
                .subscribe(new Subscriber<String>() {
                    @Override
                    public void onCompleted() {
                        onAllExecute();
                        executeOnUICompleted();
                    }
                    @Override
                    public void onError(Throwable e) {
                        Log.e(TAG, "ParallelTask onError()", e);
                    }
                    @Override
                    public void onNext(String string) {
                    }
                });

    }

    /**
     * 最后切换到UI线程执行
     */
    private void executeOnUICompleted(){
        if(uiObs != null){
            uiObs.subscribe(new Action1() {
                @Override
                public void call(Object o) {
                    onUICompleted();
                }
            });
        }
        uiObs = null;
    }

    private Observable<String> getParallelObservable(String[] methods) {
        return Observable.from(methods).flatMap(new Func1<String, Observable<String>>() {
            @Override
            public Observable<String> call(String s) {
                return Observable.just(s).subscribeOn(Schedulers.io()).map(new Func1<String, String>() {
                    @Override
                    public String call(String s) {
                        if ("async1".equals(s)) {
                            async1();
                        } else if ("async2".equals(s)) {
                            async2();
                        } else if ("async3".equals(s)) {
                            async3();
                        } else if ("async4".equals(s)) {
                            async4();
                        } else if ("async5".equals(s)) {
                            async5();
                        } else if ("async6".equals(s)) {
                            async6();
                        } else if ("async7".equals(s)) {
                            async7();
                        } else if ("async8".equals(s)) {
                            async8();
                        }
                        return s;
                    }
                });
            }
        });
    }

    /**
     * 获取被重写的方法
     * @return
     */
    private List<String> getOverrideMethods() {
        List<String> overrideMethods = new ArrayList<>();
        Method[] bfs = getClass().getDeclaredMethods();
        Method[] afs = ParallelTask.class.getDeclaredMethods();
        for (Method bm : bfs) {
            for (Method am : afs) {
                if (bm.getName().equals(am.getName()) &&
                        bm.getReturnType().equals(am.getReturnType())) {
                    Class[] bc = bm.getParameterTypes();
                    Class[] ac = am.getParameterTypes();
                    if (bc.length == ac.length) {
                        boolean isEqual = true;
                        for (int i = 0; i < bc.length; i++) {
                            if (!bc[i].equals(ac[i])) {
                                isEqual = false;
                                break;
                            }
                        }
                        if (isEqual) {
                            String name = bm.getName();
                            overrideMethods.add(name);
                        }
                    }
                }
            }
        }
        return overrideMethods;
    }

}

实现了ParallelTask抽象类,可以同时执行8个任务,用户可以自己增加个数。用户可以创建一个ParallelTask类,然后实现async1方法,按照自己的需求实现其他方法即可。

相关文章

  • 多任务同时进行

    多任务同时进行 问题:如果有一个对数据进行权限检查的操作,可能有1万条、10万条等等,只写一个任务执行它会花费很多...

  • 06.系统编程-1.进程

    1、多任务的引入 实现类似唱歌又跳舞的任务同时进行的,叫做:多任务 2、多任务的概念 什么叫“多任务”。简单地说,...

  • 053 python多任务多线程

    5. 多任务-线程 5.1. 多任务的介绍 多任务介绍 现实生活中 有很多的场景中的事情是同时进行的,比如开车的时...

  • 2019-06-16线程

    多任务,多个任务同时进行,多进程,多线程=======》几个函数同时进行。。。。。之前未学习之前代码都是一步一步进...

  • 并发,并行 | 同步,异步 | 阻塞,非阻塞

    并发:一个处理器同时处理多个任务,在多个任务间快速切换,实现多任务同时运行的效果。称为并发 并行:多个任务同时进行...

  • python实现多任务方式

    什么是多任务?就是操作系统可以同时运行多个任务 多任务的执行方式并发:交替执行,是假的多任务并行:同时执行,是真的...

  • 多任务、并发和并行

    多任务 现实生活中的多任务 有很多的场景中的事情是同时进行的,比如开车的时候 手和脚共同来驾驶汽车,再比如唱歌跳舞...

  • UCOS-III 信号量的那些事

    一.为什么要使用信号量? 当多任务对于共享资源区同时进行访问时,例如创建两个任务同时对某个数组进行输入时,如果不使...

  • python 进程

    一多任务的引入 有很多的场景中的事情是同时进行的,比如开车的时候手和脚共同来驾驶汽车,再比如唱歌跳舞也是同时进行的...

  • Java的线程、创建线程的 3 种方式、Lambda表达式简化线

    介绍 线程:多个任务同时进行,看似多任务同时进行,但实际上一个时间点上我们大脑还是只在做一件事情。程序也是如此,除...

网友评论

      本文标题:多任务同时进行

      本文链接:https://www.haomeiwen.com/subject/cpqbhxtx.html