• Android AsyncTask 分析内部实现


    sdk3.0前,使用内部的线程池,多线程并发运行。线程池大小等于5,最大达128

    sdk3.0后,使用默认的serial线程池。运行完一个线程,再顺序运行下一个线程。sdk3.0<=current version <= sdk4.3时 线程池大小等于5,最大达128

    sdk4.4后线程池大小等于 cpu count + 1。最大值为cpu count * 2 + 1

    sdk3.0后有两种线程池的实现,默觉得 Serial 线程池

    public static final Executor SERIAL_EXECUTOR = new SerialExecutor();
    public static final Executor THREAD_POOL_EXECUTOR
                = new ThreadPoolExecutor(CORE_POOL_SIZE, MAXIMUM_POOL_SIZE, KEEP_ALIVE,
                        TimeUnit.SECONDS, sPoolWorkQueue, sThreadFactory);
    private static volatile Executor sDefaultExecutor = SERIAL_EXECUTOR;
    public static void setDefaultExecutor(Executor exec) {//设置默认线程池
            sDefaultExecutor = exec;
    }
    SerialExecutor ,使用同步锁,一次运行一个线程

    private static class SerialExecutor implements Executor {
            final ArrayDeque<Runnable> mTasks = new ArrayDeque<Runnable>();
            Runnable mActive;
    
            public synchronized void execute(final Runnable r) {
                mTasks.offer(new Runnable() {
                    public void run() {
                        try {
                            r.run();
                        } finally {
                            scheduleNext();
                        }
                    }
                });
                if (mActive == null) {
                    scheduleNext();
                }
            }
    
            protected synchronized void scheduleNext() {
                if ((mActive = mTasks.poll()) != null) {
                    THREAD_POOL_EXECUTOR.execute(mActive);
                }
            }
        }

    THREAD_POOL_EXECUTOR 并发线程池

    asynctask.setDefaultExecutor(AsyncTask.THREAD_POOL_EXECUTOR); //设置使用 并发线程池 

    //params 都是使用在doInBackground(Params... params);

    asynctask.executeOnExecutor(executor, params); //能够自己定义 线程池     使用这两种方法

  • 相关阅读:
    java中string与json互相转化
    UVa 10125
    IOS开发之蘑菇街框架
    从头认识设计模式-策略模式-03-思考过程二:在每个类里面单独添加方法或者添加接口
    使用spring-loaded开源项目,实现java程序和web应用的热部署
    矩阵高速幂专题(二)
    EBS 第一个项目 学习总结 ---- 发运模块
    关于App程序猿泡沫
    Go 语言编程
    jar运行main函数的方法
  • 原文地址:https://www.cnblogs.com/mthoutai/p/6895100.html
Copyright © 2020-2023  润新知