⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 threadpool.java

📁 是离开的肌肤了卡机是离开的就富利卡及是了的开发及拉考试及的福利科技阿斯利康的肌肤莱卡及时的离开福建阿斯顿发
💻 JAVA
字号:
// ========================================================================// Copyright 2004-2005 Mort Bay Consulting Pty. Ltd.// ------------------------------------------------------------------------// 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 org.mortbay.thread.concurrent;import java.util.concurrent.ArrayBlockingQueue;import java.util.concurrent.BlockingQueue;import java.util.concurrent.LinkedBlockingQueue;import java.util.concurrent.RejectedExecutionException;import java.util.concurrent.RejectedExecutionHandler;import java.util.concurrent.SynchronousQueue;import java.util.concurrent.ThreadFactory;import java.util.concurrent.ThreadPoolExecutor;import java.util.concurrent.TimeUnit;import org.mortbay.component.LifeCycle;import org.mortbay.log.Log;/* ------------------------------------------------------------ *//** Jetty ThreadPool using java 5 ThreadPoolExecutor * This class wraps a {@link ThreadPoolExecutor} with the {@link org.mortbay.thread.ThreadPool} and  * {@link LifeCycle} interfaces so that it may be used by the Jetty {@link org.mortbay.jetty.Server} *  * @author gregw * */public class ThreadPool extends ThreadPoolExecutor implements org.mortbay.thread.ThreadPool, LifeCycle{        /* ------------------------------------------------------------ */    /** Default constructor.     * Core size is 32, max pool size is 256, pool thread timeout after 60 seconds and     * an unbounded {@link LinkedBlockingQueue} is used for the job queue;     */    public ThreadPool()    {        super(32,256,60,TimeUnit.SECONDS,new LinkedBlockingQueue<Runnable>());    }        /* ------------------------------------------------------------ */    /** Default constructor.     * Core size is 32, max pool size is 256, pool thread timeout after 60 seconds     * @param queueSize if -1, an unbounded {@link LinkedBlockingQueue} is used, if 0 then a     * {@link SynchronousQueue} is used, other a {@link ArrayBlockingQueue} of the given size is used.     */    public ThreadPool(int queueSize)    {        super(32,256,60,TimeUnit.SECONDS,                queueSize<0?new LinkedBlockingQueue<Runnable>()                        : (queueSize==0?new SynchronousQueue<Runnable>()                                :new ArrayBlockingQueue<Runnable>(queueSize)));    }    /* ------------------------------------------------------------ */    /** Size constructor.     * an unbounded {@link LinkedBlockingQueue} is used for the jobs queue;     */    public ThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit)    {        super(corePoolSize,maximumPoolSize,keepAliveTime,unit,new LinkedBlockingQueue<Runnable>());    }    /* ------------------------------------------------------------ */    public ThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue)    {        super(corePoolSize,maximumPoolSize,keepAliveTime,unit,workQueue);    }    /* ------------------------------------------------------------ */    public ThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, RejectedExecutionHandler handler)    {        super(corePoolSize,maximumPoolSize,keepAliveTime,unit,workQueue,handler);    }    /* ------------------------------------------------------------ */    public ThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory, RejectedExecutionHandler handler)    {        super(corePoolSize,maximumPoolSize,keepAliveTime,unit,workQueue,threadFactory,handler);    }    /* ------------------------------------------------------------ */    public ThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory)    {        super(corePoolSize,maximumPoolSize,keepAliveTime,unit,workQueue,threadFactory);    }    /* ------------------------------------------------------------ */    public boolean dispatch(Runnable job)    {        try        {                   execute(job);            return true;        }        catch(RejectedExecutionException e)        {            Log.warn(e);            return false;        }    }    /* ------------------------------------------------------------ */    public int getIdleThreads()    {        return getPoolSize()-getActiveCount();    }    /* ------------------------------------------------------------ */    public int getThreads()    {        return getPoolSize();    }    /* ------------------------------------------------------------ */    public boolean isLowOnThreads()    {        return getActiveCount()>=getMaximumPoolSize();    }    /* ------------------------------------------------------------ */    public void join() throws InterruptedException    {        this.awaitTermination(Long.MAX_VALUE,TimeUnit.MILLISECONDS);    }    /* ------------------------------------------------------------ */    public boolean isFailed()    {        return false;    }    /* ------------------------------------------------------------ */    public boolean isRunning()    {        return !isTerminated() && !isTerminating();    }    /* ------------------------------------------------------------ */    public boolean isStarted()    {        return !isTerminated() && !isTerminating();    }    /* ------------------------------------------------------------ */    public boolean isStarting()    {        return false;    }    /* ------------------------------------------------------------ */    public boolean isStopped()    {        return isTerminated();    }    /* ------------------------------------------------------------ */    public boolean isStopping()    {        return isTerminating();    }    /* ------------------------------------------------------------ */    public void start() throws Exception    {        if (isTerminated() || isTerminating() || isShutdown())            throw new IllegalStateException("Cannot restart");    }    /* ------------------------------------------------------------ */    public void stop() throws Exception    {        super.shutdown();        if (!super.awaitTermination(60,TimeUnit.SECONDS))            super.shutdownNow();    }    /* ------------------------------------------------------------ */    public void addLifeCycleListener(LifeCycle.Listener listener)    {        throw new UnsupportedOperationException();    }        /* ------------------------------------------------------------ */    public void removeLifeCycleListener(LifeCycle.Listener listener)    {    }    }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -