JAVA ThreadPool & ThreadFactory

简介: <p><br></p> <p></p><pre code_snippet_id="472847" snippet_file_name="blog_20140922_1_6474226" name="code" class="java">package threadPool;import java.util.concurrent.ThreadFactory;import java.


package threadPool;

import java.util.concurrent.ThreadFactory;
import java.util.concurrent.atomic.AtomicInteger;

/**
 * @ClassName: BasicThreadFactory
 * @Description: TODO
 * @author Zhou Shengshuai
 * @date 2014年9月22日 上午10:09:30
 * 
 */
public class BasicThreadFactory implements ThreadFactory {
	private final ThreadGroup threadGroup;
	private final AtomicInteger threadNumber = new AtomicInteger(1);
	private final String threadNamePrefix;

	/**
	 * 构造函数
	 * 
	 * @param threadPoolName
	 *            线程池名称
	 */
	public BasicThreadFactory(String threadPoolName) {
		SecurityManager securityManager = System.getSecurityManager();

		threadGroup = (securityManager != null) ? securityManager.getThreadGroup() : Thread.currentThread().getThreadGroup();

		threadNamePrefix = threadPoolName + "-thread-";
	}

	/**
	 * 创建线程
	 */
	@Override
	public Thread newThread(Runnable runnable) {
		Thread thread = new Thread(threadGroup, runnable, threadNamePrefix + threadNumber.getAndIncrement(), 0);

		if (thread.isDaemon()) {
			thread.setDaemon(false);
		}

		if (thread.getPriority() != Thread.MAX_PRIORITY) {
			thread.setPriority(Thread.MAX_PRIORITY);
		}

		return thread;
	}
}

package threadPool;

/**
 * @ClassName: BasicThreadTask
 * @Description: TODO
 * @author Zhou Shengshuai
 * @date 2014年9月22日 上午10:12:02
 * 
 */
public class BasicThreadTask implements Runnable {

	@Override
	public void run() {
		System.out.println(Thread.currentThread().getName());
	}

}

package threadPool;

import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;

/**
 * @ClassName: MainThreadTask
 * @Description: TODO
 * @author Zhou Shengshuai
 * @date 2014年9月22日 上午10:14:34
 * 
 */
public class MainThreadTask {
	private ThreadPoolExecutor threadPoolExecutor = null;

	public void initial() {
		threadPoolExecutor = (ThreadPoolExecutor) Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors(), new BasicThreadFactory("BasicThreadFactory"));
	}

	public void execute() {
		for (int index = 0; index < 10; index++) {
			threadPoolExecutor.execute(new BasicThreadTask());
		}
	}

	public void destroy() {
		threadPoolExecutor.shutdown();
	}

	/**
	 * @Title: main
	 * @Description: TODO
	 * @param args
	 * @throws
	 */
	public static void main(String[] args) {
		MainThreadTask mainThreadTask = new MainThreadTask();

		mainThreadTask.initial();
		mainThreadTask.execute();
		mainThreadTask.destroy();
	}

}


相关文章
|
7月前
|
Java 调度
Java多线程:什么是线程池(ThreadPool)?
Java多线程:什么是线程池(ThreadPool)?
101 0
|
5月前
|
Java 开发者
Java面试题:解释Java内存模型中的内存可见性,解释Java中的线程池(ThreadPool)的工作原理,解释Java中的CountDownLatch和CyclicBarrier的区别
Java面试题:解释Java内存模型中的内存可见性,解释Java中的线程池(ThreadPool)的工作原理,解释Java中的CountDownLatch和CyclicBarrier的区别
27 0
|
5月前
|
存储 算法 Java
Java面试题:详细描述Java堆内存的垃圾回收过程,解释Java中的线程池(ThreadPool)的工作原理,解释Java中的FutureTask的工作原理
Java面试题:详细描述Java堆内存的垃圾回收过程,解释Java中的线程池(ThreadPool)的工作原理,解释Java中的FutureTask的工作原理
33 0
|
算法 Java Linux
java中ThreadPool的介绍和使用
java中ThreadPool的介绍和使用
java中ThreadPool的介绍和使用
|
Java Linux
Java ThreadPool 实现
前面我们已经介绍了 JDK 中常用的并发库(JUC)的使用方式, 本文我们着重介绍 JUC 中 ThreadPool 的实现方式。
|
安全 Java
java安全编码指南之:ThreadPool的使用
java安全编码指南之:ThreadPool的使用
|
Java 开发者
Java常见面试题:ThreadLocal和ThreadPool原理以及应用场景
线程池的概念在一些公司的笔试里面经常会出现,大家只需要清楚无限制增长、定长执行、定时操作、单线程池这四种线程池的操作就可以了。
Java常见面试题:ThreadLocal和ThreadPool原理以及应用场景
|
10天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####
|
1天前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####
|
1天前
|
安全 Java 开发者
Java中的多线程编程:从基础到实践
本文深入探讨了Java多线程编程的核心概念和实践技巧,旨在帮助读者理解多线程的工作原理,掌握线程的创建、管理和同步机制。通过具体示例和最佳实践,本文展示了如何在Java应用中有效地利用多线程技术,提高程序性能和响应速度。
16 1
下一篇
无影云桌面