Android Open Source - Arbalest Async Processor






From Project

Back to project page Arbalest.

License

The source code is released under:

Apache License

If you think the Android project Arbalest 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) 2013 KeithYokoma. All rights reserved.
 */* ww  w .j  ava 2 s .com*/
 * 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.arbalest.concurrent;

import java.util.concurrent.BlockingQueue;
import java.util.concurrent.Executor;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;

public class AsyncProcessor {
    public static final String TAG = AsyncProcessor.class.getSimpleName();
    private static final int CORE_THREAD_POOL_SIZE = 3;
    private static final int MAX_THREAD_POOL_SIZE = 64;
    private static final int KEEP_ALIVE = 1;
    private static final int POOL_WORK_QUEUE_CAPACITY = 10;
    private static final BlockingQueue<Runnable> sWorkQueue = new LinkedBlockingQueue<Runnable>(POOL_WORK_QUEUE_CAPACITY);
    private static final ThreadFactory sThreadFactory = new ThreadFactory() {
        private final AtomicInteger mCount = new AtomicInteger(1);
        @Override
        public Thread newThread(Runnable r) {
            return new Thread(r, TAG + " #" + mCount.getAndIncrement());
        }
    };
    private static final Executor sThreadPoolExecutor = new ThreadPoolExecutor(
            CORE_THREAD_POOL_SIZE, MAX_THREAD_POOL_SIZE, KEEP_ALIVE, TimeUnit.SECONDS, sWorkQueue, sThreadFactory);

    public static final void process(Runnable runnable) {
        sThreadPoolExecutor.execute(runnable);
    }
}




Java Source Code List

com.arbalest.ArbalestContext.java
com.arbalest.Arbalest.java
com.arbalest.callback.ArbalestCallbackManager.java
com.arbalest.callback.ArbalestCallback.java
com.arbalest.concurrent.AsyncProcessor.java
com.arbalest.constants.ArbalestConstants.java
com.arbalest.exception.ArbalestAuthenticationException.java
com.arbalest.exception.ArbalestConnectionException.java
com.arbalest.exception.ArbalestException.java
com.arbalest.exception.ArbalestNetworkException.java
com.arbalest.exception.ArbalestRequestException.java
com.arbalest.exception.ArbalestResponseException.java
com.arbalest.http.ArbalestClientFactory.java
com.arbalest.http.ArbalestClient.java
com.arbalest.http.IArbalestClientFactory.java
com.arbalest.http.IArbalestClient.java
com.arbalest.net.Binary.java
com.arbalest.net.annotation.ConvertedBy.java
com.arbalest.net.converter.BinaryConverter.java
com.arbalest.net.converter.Converter.java
com.arbalest.net.converter.EntityConversionPolicy.java
com.arbalest.net.converter.EntityConversionStrategy.java
com.arbalest.net.converter.GsonConverter.java
com.arbalest.net.converter.RawJsonConverter.java
com.arbalest.net.json.ArbalestFieldNamingStrategy.java
com.arbalest.utils.ArbalestCallbackUtils.java