线程池

Posted Ipeter

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了线程池相关的知识,希望对你有一定的参考价值。

线程池的基本思想还是一种对象池的思想,开辟一块内存空间,里面存放了众多(未死亡)的线程,池中线程执行调度由池管理器来处理。
当有线程任务时,从池中取一个,执行完成后线程对象归池,这样可以避免反复创建线程对象所带来的性能开销,节省了系统的资源。
demo1:固定大小的线程池
package com.js.ai.modules.pointwall.interfac;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

class MyThread extends Thread{
	@Override
	public void run() {
		System.out.println(Thread.currentThread().getName()+"正在执行。。");
	}
}
public class ThreadPoolTest {
public static void main(String[] args) {
	ExecutorService pool=Executors.newFixedThreadPool(2);//创建一个可重用固定线程数的线程池 
	 //创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
	Thread t1=new MyThread();
	Thread t2=new MyThread();
	Thread t3=new MyThread();
	Thread t4=new MyThread();
	Thread t5=new MyThread();
	//将线程放入池中进行执行
	pool.execute(t1);
	pool.execute(t2);
	pool.execute(t3);
	pool.execute(t4);
	pool.execute(t5);
	 //关闭线程池
	pool.shutdown();
}
}
demo2:单任务线程池
package com.js.ai.modules.pointwall.interfac;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

class MyThread extends Thread{
	@Override
	public void run() {
		System.out.println(Thread.currentThread().getName()+"正在执行。。");
	}
}
public class ThreadPoolTest {
public static void main(String[] args) {
	ExecutorService pool=Executors.newSingleThreadExecutor();//创建一个使用单个 worker 线程的 Executor,以无界队列方式来运行该线程。
	 //创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
	Thread t1=new MyThread();
	Thread t2=new MyThread();
	Thread t3=new MyThread();
	Thread t4=new MyThread();
	Thread t5=new MyThread();
	//将线程放入池中进行执行
	pool.execute(t1);
	pool.execute(t2);
	pool.execute(t3);
	pool.execute(t4);
	pool.execute(t5);
	 //关闭线程池
	pool.shutdown();
}
}
对于demo1和demo2两种连接池,大小都是固定的,当要加入的池的线程(或者任务)超过池最大尺寸时候,则入此线程池需要排队等待。
一旦池中有线程完毕,则排队等待的某个线程会入池执行。
demo3:可变尺寸的线程池
package com.js.ai.modules.pointwall.interfac;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

class MyThread extends Thread{
	@Override
	public void run() {
		System.out.println(Thread.currentThread().getName()+"正在执行。。");
	}
}
public class ThreadPoolTest {
public static void main(String[] args) {
	ExecutorService pool=Executors.newCachedThreadPool(); //创建一个可根据需要创建新线程的线程池,但是在以前构造的线程可用时将重用它们。
	 //创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
	Thread t1=new MyThread();
	Thread t2=new MyThread();
	Thread t3=new MyThread();
	Thread t4=new MyThread();
	Thread t5=new MyThread();
	//将线程放入池中进行执行
	pool.execute(t1);
	pool.execute(t2);
	pool.execute(t3);
	pool.execute(t4);
	pool.execute(t5);
	 //关闭线程池
	pool.shutdown();
}
}
demo4:延迟连接池
package com.js.ai.modules.pointwall.interfac;


import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

class MyThread extends Thread{
	@Override
	public void run() {
		System.out.println(Thread.currentThread().getName()+"正在执行。。");
	}
}
public class ThreadPoolTest {
public static void main(String[] args) {
	//创建一个线程池,它可安排在给定延迟后运行命令或者定期地执行。
	ScheduledExecutorService pool=Executors.newScheduledThreadPool(2); 
	 //创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
	Thread t1=new MyThread();
	Thread t2=new MyThread();
	Thread t3=new MyThread();
	Thread t4=new MyThread();
	Thread t5=new MyThread();
	//将线程放入池中进行执行
	pool.execute(t1);
	pool.execute(t2);
	pool.execute(t3);
	//使用延迟执行风格的方法 
	pool.schedule(t4,10,TimeUnit.MILLISECONDS);
	pool.schedule(t5,10,TimeUnit.MILLISECONDS);
	 //关闭线程池
	pool.shutdown();
}
}

  

demo5:单任务延迟连接池
package com.js.ai.modules.pointwall.interfac;


import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

class MyThread extends Thread{
	@Override
	public void run() {
		System.out.println(Thread.currentThread().getName()+"正在执行。。");
	}
}
public class ThreadPoolTest {
public static void main(String[] args) {
	 //创建一个单线程执行程序,它可安排在给定延迟后运行命令或者定期地执行。
	ScheduledExecutorService pool=Executors.newSingleThreadScheduledExecutor(); 
	 //创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
	Thread t1=new MyThread();
	Thread t2=new MyThread();
	Thread t3=new MyThread();
	Thread t4=new MyThread();
	Thread t5=new MyThread();
	//将线程放入池中进行执行
	pool.execute(t1);
	pool.execute(t2);
	pool.execute(t3);
	//使用延迟执行风格的方法 
	pool.schedule(t4,10,TimeUnit.MILLISECONDS);
	pool.schedule(t5,10,TimeUnit.MILLISECONDS);
	 //关闭线程池
	pool.shutdown();
}
}

  

demo6:自定义线程池
package com.js.ai.modules.pointwall.interfac;


import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

class MyThread extends Thread{
	@Override
	public void run() {
		System.out.println(Thread.currentThread().getName()+"正在执行。。");
	}
}
public class ThreadPoolTest {
public static void main(String[] args) {
	//创建等待队列
	BlockingQueue<Runnable> bqueue=new ArrayBlockingQueue<Runnable>(20);
	//创建一个单线程执行程序,它可安排在给定延迟后运行命令或者定期地执行。 
	ThreadPoolExecutor pool=new ThreadPoolExecutor(2, 3, 2, TimeUnit.MILLISECONDS, bqueue);
	//创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
	Thread t1=new MyThread();
	Thread t2=new MyThread();
	Thread t3=new MyThread();
	Thread t4=new MyThread();
	Thread t5=new MyThread();
	Thread t6=new MyThread();
	Thread t7=new MyThread();
	//将线程放入池中进行执行
	pool.execute(t1);
	pool.execute(t2);
	pool.execute(t3);
	pool.execute(t4);
	pool.execute(t5);
	pool.execute(t6);
	pool.execute(t7);
	 //关闭线程池
	pool.shutdown();
}
}

  

以上是关于线程池的主要内容,如果未能解决你的问题,请参考以下文章

Java——线程池

Motan在服务provider端用于处理request的线程池

Java线程池详解

Java线程池详解

Java 线程池详解

线程池-实现一个取消选项