Android Open Source - Android-SDK Dispatcher






From Project

Back to project page Android-SDK.

License

The source code is released under:

Apache License

If you think the Android project Android-SDK listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/*
 * Copyright (C) 2014. BaasBox//from www.j a  va  2s. c  o m
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *       http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and limitations under the License.
 */

package com.baasbox.android.impl;

import android.os.Handler;
import android.os.Looper;
import android.os.Process;
import com.baasbox.android.BaasBox;
import com.baasbox.android.BaasHandler;
import com.baasbox.android.BaasResult;
import com.baasbox.android.ExceptionHandler;

import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.PriorityBlockingQueue;
import java.util.concurrent.atomic.AtomicInteger;

/**
 * Created by Andrea Tortorella on 20/01/14.
 */
public final class Dispatcher {
// ------------------------------ FIELDS ------------------------------

    private static final AtomicInteger SEQUENCE = new AtomicInteger();

    final Handler defaultMainHandler = new Handler(Looper.getMainLooper());


    private final PriorityBlockingQueue<Task<?>> taskQueue;
    private final ConcurrentMap<Integer, Task<?>> liveAsyncs;
    private final ExceptionHandler exceptionHandler;
    private final Worker[] workers;
    private final BaasBox box;
    private volatile boolean quit;

// --------------------------- CONSTRUCTORS ---------------------------
    public Dispatcher(BaasBox box) {
        this.box = box;
        this.exceptionHandler = setHandler(box.config.exceptionHandler);
        this.workers = createWorkers(box.config.workerThreads);
        this.taskQueue = new PriorityBlockingQueue<Task<?>>(16);
        this.liveAsyncs = new ConcurrentHashMap<Integer, Task<?>>(16, 0.75f, 1);
    }

    private static ExceptionHandler setHandler(ExceptionHandler handler) {
        if (handler == null) {
            Logger.warn("exceptionHandler is null: set using default");
            return ExceptionHandler.DEFAULT;
        }
        return handler;
    }

    private static Worker[] createWorkers(int threads) {
        if (threads < 0) {
            Logger.warn("Ignoring workerThreads: less than 0 threads, default will be used");
            threads = 0;
        }
        if (threads == 0) {
            threads = Runtime.getRuntime().availableProcessors();
            Logger.info("Using default number of threads configuration %s", threads);
        }
        return new Worker[threads];
    }

// -------------------------- OTHER METHODS --------------------------

    public <R> BaasResult<R> await(int requestId) {
        Task<R> task = (Task<R>) liveAsyncs.get(requestId);
        if (task == null) {
            return null;
        } else if (task.result != null) {
            return task.result;
        } else {
            task.await();
            return task.result;
        }
    }

    public boolean cancel(int requestId, boolean immediate) {
        Task<?> task = liveAsyncs.get(requestId);
        if (task == null) return false;
        if (immediate) {
            return task.abort();
        } else {
            return task.cancel();
        }
    }

    void finish(Task<?> req) {
        this.liveAsyncs.remove(req.seqNumber, req);
        Logger.info("%s finished", req);
    }

    public int post(Task<?> request) {
        final int seqNumber = SEQUENCE.getAndIncrement();
        request.bind(seqNumber, this);
        liveAsyncs.put(seqNumber, request);
        taskQueue.add(request);
        return seqNumber;
    }

    public <R> boolean resume(int requestId, BaasHandler<R> handler) {
        Task<R> task = (Task<R>) liveAsyncs.get(requestId);
        if (task == null) {
            return false;
        }
        return task.resume(handler);
    }

    public void start() {
        stop();
        quit = false;
        for (int i = 0; i < workers.length; i++) {
            workers[i] = new Worker(this);
            workers[i].start();
        }
    }

    public void stop() {
        quit = true;
        for (int i = 0; i < workers.length; i++) {
            if (workers[i] != null) {
                workers[i].interrupt();
                workers[i] = null;
            }
        }
    }

    public boolean suspend(int requestId) {
        Task<?> task = liveAsyncs.get(requestId);
        return task != null && task.suspend();
    }

// -------------------------- INNER CLASSES --------------------------

    private static final class Worker extends Thread {
        private final PriorityBlockingQueue<Task<?>> queue;
        private final Dispatcher dispatcher;

        Worker(Dispatcher dispatcher) {
            this.dispatcher = dispatcher;
            this.queue = dispatcher.taskQueue;
        }

        @Override
        public void run() {
            Process.setThreadPriority(Process.THREAD_PRIORITY_BACKGROUND);
            Task<?> task;
            while (true) {
                try {
                    task = queue.take();
                } catch (InterruptedException e) {
                    if (dispatcher.quit) return;
                    continue;
                }
                try {
                    task.execute();
                    task.post();
                    task.unlock();
                } catch (Exception t) {
                    if (dispatcher.exceptionHandler.onError(t)) {
                        Logger.error(t,"Dispatcher error");
                    }
                }
            }
        }
    }
}




Java Source Code List

com.baasbox.android.AsyncStream.java
com.baasbox.android.BaasACL.java
com.baasbox.android.BaasApiException.java
com.baasbox.android.BaasAssetId.java
com.baasbox.android.BaasAsset.java
com.baasbox.android.BaasBox.java
com.baasbox.android.BaasCancellationException.java
com.baasbox.android.BaasClientException.java
com.baasbox.android.BaasCloudMessagingService.java
com.baasbox.android.BaasCredentialManager.java
com.baasbox.android.BaasDocument.java
com.baasbox.android.BaasException.java
com.baasbox.android.BaasFile.java
com.baasbox.android.BaasHandler.java
com.baasbox.android.BaasIOException.java
com.baasbox.android.BaasInvalidSessionException.java
com.baasbox.android.BaasLink.java
com.baasbox.android.BaasObject.java
com.baasbox.android.BaasQuery.java
com.baasbox.android.BaasResult.java
com.baasbox.android.BaasRuntimeException.java
com.baasbox.android.BaasServerException.java
com.baasbox.android.BaasStream.java
com.baasbox.android.BaasUser.java
com.baasbox.android.Cache.java
com.baasbox.android.DataStreamHandler.java
com.baasbox.android.ExceptionHandler.java
com.baasbox.android.FixedByteArrayOutputStream.java
com.baasbox.android.Grant.java
com.baasbox.android.HttpUrlConnectionClient.java
com.baasbox.android.JsonWrapper.java
com.baasbox.android.NetworkTask.java
com.baasbox.android.Plugin.java
com.baasbox.android.RequestFactory.java
com.baasbox.android.RequestOptions.java
com.baasbox.android.RequestToken.java
com.baasbox.android.RestImpl.java
com.baasbox.android.Rest.java
com.baasbox.android.Role.java
com.baasbox.android.SaveMode.java
com.baasbox.android.StreamBody.java
com.baasbox.android.StreamRequest.java
com.baasbox.android.impl.Base64.java
com.baasbox.android.impl.Constants.java
com.baasbox.android.impl.DiskLruCache.java
com.baasbox.android.impl.Dispatcher.java
com.baasbox.android.impl.GCMWrapper.java
com.baasbox.android.impl.ImmediateDispatcher.java
com.baasbox.android.impl.Logger.java
com.baasbox.android.impl.StrictLineReader.java
com.baasbox.android.impl.Task.java
com.baasbox.android.impl.Util.java
com.baasbox.android.impl.package-info.java
com.baasbox.android.json.JsonArray.java
com.baasbox.android.json.JsonException.java
com.baasbox.android.json.JsonObject.java
com.baasbox.android.json.JsonReader.java
com.baasbox.android.json.JsonScope.java
com.baasbox.android.json.JsonStructure.java
com.baasbox.android.json.JsonToken.java
com.baasbox.android.json.JsonWriter.java
com.baasbox.android.json.StringPool.java
com.baasbox.android.json.package-info.java
com.baasbox.android.net.HttpRequest.java
com.baasbox.android.net.OkClient.java
com.baasbox.android.net.RestClient.java
com.baasbox.android.plugins.glide.BaasAssetModelLoader.java
com.baasbox.android.plugins.glide.BaasFileModelLoader.java
com.baasbox.android.plugins.glide.BaasImageFetcher.java
com.baasbox.android.plugins.glide.GlidePlugin.java
com.baasbox.android.samples.aloa.Aloa.java
com.baasbox.android.samples.aloa.ApplicationTest.java
com.baasbox.android.samples.aloa.Configuration.java
com.baasbox.android.samples.aloa.Data.java
com.baasbox.android.samples.aloa.activities.CreateChannelFragment.java
com.baasbox.android.samples.aloa.activities.LoginActivity.java
com.baasbox.android.samples.aloa.activities.MainActivity.java
com.baasbox.android.samples.aloa.activities.OnTargetSelectedListener.java
com.baasbox.android.samples.aloa.activities.SendMessageActivity.java
com.baasbox.android.samples.aloa.activities.SendTargetFragment.java
com.baasbox.android.samples.aloa.activities.UserStatusFragment.java
com.baasbox.android.samples.aloa.activities.loaders.BaasUsersLoader.java
com.baasbox.android.samples.aloa.activities.loaders.ChannelsLoader.java
com.baasbox.android.samples.aloa.receive.NewMessageNotification.java
com.baasbox.android.samples.aloa.receive.PushReceiver.java
com.baasbox.android.samples.aloa.utils.BaasLoader.java
com.baasbox.android.samples.aloa.utils.BaseActivity.java
com.baasbox.android.samples.aloa.utils.BaseBaasLoader.java
com.baasbox.android.samples.aloa.utils.BaseFragment.java
com.baasbox.android.samples.phrasebook.Configuration.java
com.baasbox.android.samples.phrasebook.Phrasebook.java
com.baasbox.android.samples.phrasebook.ServerContract.java
com.baasbox.android.samples.phrasebook.common.BaseActivity.java
com.baasbox.android.samples.phrasebook.common.BaseFragment.java
com.baasbox.android.samples.phrasebook.loaders.BaasDocumentsLoader.java
com.baasbox.android.samples.phrasebook.ui.HomeActivity.java
com.baasbox.android.samples.phrasebook.ui.PhraseOfTheDay.java
com.baasbox.android.samples.phrasebook.utils.ThreadLocalRandom.java
com.baasbox.android.package-info.java