Java examples for java.util.concurrent:Executors
thread Per Cpu Executor
/**************************************************************************** * Copyright 2010 Huascar A. Sanchez * * * * 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.java2s; import java.util.concurrent.ExecutorService; import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.ThreadFactory; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; public class Main { public static ExecutorService threadPerCpuExecutor(String name) { return fixedThreadsExecutor(name, Runtime.getRuntime() .availableProcessors()); }//from ww w .ja v a2 s. com public static ExecutorService fixedThreadsExecutor(String name, int count) { ThreadFactory threadFactory = daemonThreadFactory(name); return new ThreadPoolExecutor(count, count, 10, TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>(Integer.MAX_VALUE), threadFactory) { @Override protected void afterExecute(Runnable runnable, Throwable throwable) { if (throwable != null) { //Console.getInstance().info("Unexpected failure from " + runnable, throwable); } } }; } public static ThreadFactory daemonThreadFactory(final String name) { return new ThreadFactory() { private int nextId = 0; public synchronized Thread newThread(Runnable r) { Thread thread = new Thread(r, name + "-" + (nextId++)); thread.setDaemon(true); return thread; } }; } }