简单易懂的多线程轮询任务
学习记录
代码如下:
@org.junit.Test
public void sync()throws Exception {
//模拟一个任务,该集合存放1~100的数字,供线程读取
List<String> list = new ArrayList<>();
for (int i = 0; i < 130; i++) {
list.add("task"+ i + ",");
}
//线程数,可以修改成任意数量线程
int threadCount = 5;
//创建threadCount数量的线程
TestThread[] threads = new TestThread[threadCount];
for(int i=0; i<threadCount; i++) {
threads[i] = new TestThread(i);
}
//线程轮询并把集合中的值存放到Thrend类的tasks集合中
for (int i = 0; i<list.size(); i++){
int thread = i%threadCount;
threads[thread].addTask(list.get(i));
}
//启动线程
for(int i=0; i<threadCount; i++) {
threads[i].start();
Thread.sleep(1000);//休眠1s,不然可能线程挂机
}
}
//线程类
class TestThread extends Thread {
private int threadId;
//有参构造函数用于存放线程
public TestThread(int id) {
this.threadId = id;
}
private List<String> tasks = new ArrayList<>();
public void addTask(String task) {
tasks.add(task);
}
//执行任务的run方法
public void run() {
for(String task:tasks) {
System.out.println(""+threadId+":"+task);
}
}
}
结果如下: