欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

手把手教你在项目中使用线程池,将代码拿上,其中核心代码改为你的就可以

程序员文章站 2022-05-01 13:03:59
...

线程池背景知识

涉及到的是java.util.concurrent包中的ExecutorService。ExecutorService就是Java中对线程池的实现。
Java API对ExecutorService接口的实现有两个,所以这两个即是Java线程池具体实现类

1. ThreadPoolExecutor
2. ScheduledThreadPoolExecutor

创建线程池

创建一个什么样的ExecutorService的实例(即线程池)需要根据具体应用场景而定,不过Java给我们提供了一个Executors工厂类,它可以帮助我们很方便的创建各种类型ExecutorService线程池,Executors一共可以创建下面这四类线程池:

1. newCachedThreadPool 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
2. newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
3. newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。
4. newSingleThreadExecutor 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

备注:Executors只是一个工厂类,它所有的方法返回的都是ThreadPoolExecutor、ScheduledThreadPoolExecutor这两个类的实例。

ExecutorService的使用

ExecutorService executorService = Executors.newFixedThreadPool(10);

executorService.execute(new Runnable() {
public void run() {
将我们代码中要执行的代码放到这个里面就可以了
    System.out.println("Asynchronous task");
}
});

executorService.shutdown();

具体例子如下:

	List<User> userxx = UserMapper.getUserxx();
		//采用ExecutorService提供的java线程池
		ExecutorService cacheExecutor = Executors.newFixedThreadPool(100);
		if(userxx != null && userxx .size()>0){
			for(User  duser:userxx ){

				cacheExecutor.execute(new Runnable() {
					public void run() {
						try {
							insertXcc(duser);
						} catch (Exception e) {
							e.printStackTrace();
						}
					}
				});
			}

		}
		cacheExecutor.shutdown();

以上是要往数据库插入很多的信息,所以可以使用线程池,以后使用线程池,可以按照上面的格式改一下就可以了

相关标签: 线程池 线程池