package com.dada.executorService;
import java.util.concurrent.TimeUnit;
public class JobThread extends Thread {
// 为线程命名
public JobThread(String name,long threadId) {
super(name);
}
@Override
public void run() {
// 如果主线程包含这个线程就一直运行
while (MainThread.threadNameMap.containsKey(this.getName())) {
try {
System.out.println("线程名称:-----" + this.getName());
TimeUnit.SECONDS.sleep(4);
} catch (Exception e) {
e.printStackTrace();
}
}
System.out.println("***************线程结束,线程名称:*********" + this.getName());
}
}
package com.dada.executorService;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
public class MainThread {
public static final int THREADPOOL_SIZE = 5;
// 生成固定大小的线程池
public static ExecutorService exec = Executors.newFixedThreadPool(THREADPOOL_SIZE);
// 用来存储线程名称的map
public static Map<String, String> threadNameMap = new HashMap<String, String>();
public static void main(String[] args) {
// 向线程池中插入 10 个线程,但是线程池只允许最大 5 个线程,所以其他 5 个线程等待中
for (int i = 0; i < THREADPOOL_SIZE + 5; i++) {
String threadName = getThreadName(i);
threadNameMap.put(threadName, threadName);
exec.execute(new JobThread(threadName, i));
}
System.out.println("Hash表的Size:" + threadNameMap.size());
try {
System.out.println("主线程睡一会!");
TimeUnit.SECONDS.sleep(3);
} catch (Exception e) {
e.printStackTrace();
System.out.println("醒了!");
}
// 下面的这几个用来删除线程池里面的线程
//removeThread(0);
//removeThread(1);
//removeThread(2);
}
public static void removeThread(int i) {
threadNameMap.remove(getThreadName(i));
System.out.println("删除线程Thread" + i + ", Hash表的Size:" + threadNameMap.size());
}
public static String getThreadName(int i) {
return "threadname"+i;
}
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有