package com.ctl.util.ThreadPool;
import java.util.concurrent.Executor;
import java.util.concurrent.Executors;
public class Demo03 {
public static void main(String[] args) {
// execute 执行器利用 工厂方法生产对象
// 该线程池最多有三个线程
Executor executor = Executors.newFixedThreadPool(3);
executor.execute(new Dog("金毛"));
executor.execute(new Dog("哈士奇"));
executor.execute(new Dog("太迪"));
executor.execute(new Dog("阿拉斯加"));
executor.execute(new Dog("豆豆"));
executor.execute(new Dog("毛毛"));
executor.execute(new Dog("可可"));
executor.execute(new Dog("爱爱"));
}
}
class Dog implements Runnable {
String name;
public Dog(String name) {
this.name = name;
}
public void run() {
for (int i = 0; i < 3; i++) {
System.out.println(name + " 在跑 \t" + i);
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
System.err.println("InterruptedException");
}
}
System.out.println(name+"over");
}
}Executor 当n个任务要运行,线程池设为m,那么同时可运行m个,当m中的任意一个完成后,从剩余的(n-m)中在加入一个运行
最新推荐文章于 2025-07-04 09:57:49 发布
本文通过Java代码示例,详细介绍了如何使用固定大小线程池Executor和Dog类实现并发编程,展示了线程池在任务调度和资源管理方面的优势。
19

被折叠的 条评论
为什么被折叠?



