使用阻塞队列存储下载链接,使用固定数量线程池,通过实现Runnable接口提交下载任务#
public class Main {
private static final int capacity=1000;
private static BlockingQueue<String> storage=new LinkedBlockingQueue<>(capacity);
static class Downloader implements Runnable {
@Override
public void run() {
try {
System.out.println(Thread.currentThread().getName() + " downloads: " + storage.take());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
public static void main(String[] args){
for(int i=0;i<capacity;i++){
try {
storage.put("https://mydrive.com/user/gigabit/storage/file"+(i+1)+".zip");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
ThreadPoolExecutor downloaderPool=new ThreadPoolExecutor(
10,
10,
1,
TimeUnit.SECONDS,
new LinkedBlockingQueue<Runnable>());
for(int i=0;i<capacity;i++){
downloaderPool.execute(new Downloader());
}
}
}
执行结果:

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端