Java 判断线程池所有任务是否执行完毕的操作

网友投稿 539 2022-11-26


Java 判断线程池所有任务是否执行完毕的操作

我就废话不多说了,大家还是直接看代码吧~

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

public class Test {

public static void main(String args[]) throws InterruptedException {

ExecutorService exe = Executors.newFixedThreadPool(3);

for (int i = 1; i <= 5; i++) {

exe.execute(new SubThread(i));

}

exe.shutdown();

while (true) {

if (exe.isTerminated()) {

System.out.println("结束了!");

break;

}

Thread.sleep(200);

}

}

}

上面是主线程的代码,创建了一个能同时执行2个线程的线程池,并投入5个线程,当5个线程都执行完毕后打印---“结束了!”字符串。

exe.shutdown();该方法在加入线程队列的线程执行完之前不会执行。exe.isTerminated()当shutdown()或者shutdownNow()执行了之后才会执行,并返回true。

在上面的代码中必须有exe.isTerminated()的判断,否则在投入5个线程到线程池后会直接打印:“结束了”。不能达到我们想要的效果。

通过while(true)循环判断exe.isTerminated()的值,为了防止过多的判断浪费资源,可设置线程睡眠Thread.sleep(200);正是由于这个睡眠,所以当所有线程池中的线程都执行完后,有可能延迟200ms才执行"结束了"语句。这个参数越小延迟越小,结果越准确。

下面是子线程,子线程只是简单的将数字i打印出来;

public class SubThread extends Thread{

private final int i;

public SubThread(int i){

this.i = i;

hXButFz}

@Override

public void run(){

System.out.println(i);

}

}

执行结果:

3

1

4

5

2

结束了!

成功构建 (总时间: 2 秒)

子线程执行顺序不能控制,所以输出的结果是乱序的。

补充知识:java如何禁掉反射

SecurityManager

有一个checkMemberAccess这个方法可以阻止利用反射;

如:

SecurityManager sm = new SecurityManager();

sm.checkMemberAccess(Test.class, Member.PUBLIC);

前面一个为CLASS,后面需要填一个INT值,Member.PUBLIC 代表可以访问,

如果是PUBLIC,反射可以执行,DECLARED,反射运行时,会报错。

SecurityManager另外一个例子:

package com.jd.basic.pk.manager;

import java.lang.reflect.Field;

import java.security.Permission;

public class UseReflection {

static {

try {

System.setSecurityManager(new MySecurityManager());

} catch (SecurityException se) {

System.out.println("SecurityManager already set!");

}

}

public static void main(String args[]) {

Object prey = new Prey();

try {

Field pf = prey.getClass().getDeclaredField("privateString");

pf.setAccessible(true);

pf.set(prey, "Aminur test");

System.out.println(pf.get(prey));

} catch (Exception e) {

System.err.println("Caught exception " + e.toString());

}

}

}

class Prey {

@SuppressWarnings("unused")

private String privateString = "privateValue";

}

class MySecurityManager extends SecurityManager {

public void checkPermission(Permission perm) {

if (perm.getName().equals("suppressAccessChecks")) {

throw new SecurityException("Can not change the permission dude.!");

}

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:JDK1.8中ConcurrentHashMap中computeIfAbsent死循环bug问题
下一篇:基于Java Callable接口实现线程代码实例
相关文章

 发表评论

暂时没有评论,来抢沙发吧~