提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
目标实现
使用自定义的线程池进行多线程新建工作,优点是提高线程的效率。因为在有了线程池之后,新建的线程不会出现串行的情况。根据线程池的大小,每一次线程池内的所有线程均会一起执行任务,避免了串行的情况,同时也提高了线程的工作效率。
项目使用的类有MyThreadPool,WorkerThread,TaskThread和Main类,接下来将一一讲解实现原理及代码展示。
一、MyThreadPool类
该类定义了一个自定义的线程池类型,首先定义了几个属性,其中size属性表示线程池的大小,listRun是存放工作任务的链表,listWork是一个线程池,存放线程(在这里我们称这些线程为工人)。
接着进行初始化,使用构造方法对大小为size的线程池类进行初始化,其中使用到了createWorker的普通方法。
createWorker普通方法用来创建线程,使用了runnable的接口方式进行创建线程。然后执行Thread.start,会调用Thread类里面的run()方法,这个run()方法可以调用传过来的接口里的run()方法,同时将刚刚生成的新工人存放到listWrok链表中。在这其中涉及到了另外一个WorkerThread类,在该类中将进行详细讲解。
addRunnable方法,拿到传递的Runnable参数,对listRun使用synchronized关键字保证线程同步,同时使用Thread.notifyAll进行全部线程的唤醒。
import java.util.LinkedList;
public class MyThreadPool {
//共有三个属性,int类型的size(线程池内的线程数);LinkedList<Runnable>类型的listRun(任务队列);
//线程池的线程数
public int size;
//任务队列
public LinkedList<Runnable> listRun = new LinkedList<>();
//线程池
public LinkedList<WorkerThread> listWork = new LinkedList<>();
//初始化核心线程,为构造方法
public MyThreadPool (int size) {
this.size = size;
for(int i=0;i<size;i++) {
createWorker();
}
}
//为普通方法
public void createWorker(){
WorkerThread wt = new WorkerThread(listRun);
//使用runnable创建线程
new Thread(wt).start();
listWork.add(wt);
}
//为普通方法
public void addRunnable(Runnable runnable) {
synchronized (listRun) {
listRun.add(runnable);
listRun.notifyAll();
}
}
}
二、WorkerThread类
该类定义了工人线程,继承了Runnable接口,同时对run()方法进行实