跳转到帖子
  • 游客您好,欢迎来到黑客世界论坛!您可以在这里进行注册。

    赤队小组-代号1949(原CHT攻防小组)在这个瞬息万变的网络时代,我们保持初心,创造最好的社区来共同交流网络技术。您可以在论坛获取黑客攻防技巧与知识,您也可以加入我们的Telegram交流群 共同实时探讨交流。论坛禁止各种广告,请注册用户查看我们的使用与隐私策略,谢谢您的配合。小组成员可以获取论坛隐藏内容!

    TheHackerWorld官方

java异步线程_java异步线程


HACK1949

推荐的帖子

使用一个ExecutorService,增加两个不可取消的子线程任务,并且获取他们的返回值。

@org.junit.Test

public void testFuture() throws InterruptedException {

ExecutorService executor = Executors.newCachedThreadPool();

Task task = new Task();

NewTask newTask = new NewTask();

Future result = executor.submit(task);

Future ends = executor.submit(newTask);

executor.shutdown();

System.out.println("主线程开始运行");

System.out.println("主线程做一些复杂任务");

Thread.sleep(10000);

System.out.println("主线程需要子线程的计算结果");

try {

System.out.println("主线程得到子线程的结果:"+result.get());

System.out.println("主线程需要第二个子线程的数据:"+ends.get());

} catch (InterruptedException e) {

e.printStackTrace();

} catch (ExecutionException e) {

e.printStackTrace();

}

System.out.println("所有均完毕");

}

}

class Task implements Callable{

public Integer call() throws Exception {

System.out.println("子线程计算开始");

Thread.sleep(3000);

int sum = 0;

for (int i=0;i<100000;i++){

sum += i ;

}

System.out.println("子线程已经计算完毕");

return sum;

}

}

class NewTask implements Callable{

public String call() throws Exception {

System.out.println("第二个子线程已经运行完毕");

return "success";

}

}

另: 如果main主线程不去获取子线程的结果,那么主线程完全可以不阻塞。那么,此时,主线程和子线程完全异步。此功能,可以做成类似MQ消息中间件之类的,消息异步进行发送。

使用一个ExecutorService,增加两个不可取消的子线程任务,并且获取他们的返回值。 @org.junit.Test public void testFuture() throws InterruptedException { ExecutorService executor = Executors.newCachedThreadPool(); Task task = new Task(); NewTask newTask = new NewTask(); Future result = executor.submit(task); Future ends = executor.submit(newTask); executor.shutdown(); System.out.println("主线程开始运行"); System.out.println("主线程做一些复杂任务"); Thread.sleep(10000); System.out.println("主线程需要子线程的计算结果"); try { System.out.println("主线程得到子线程的结果:"+result.get()); System.out.println("主线程需要第二个子线程的数据:"+ends.get()); } catch (InterruptedException e) { e.printStackTrace(); } catch (ExecutionException e) { e.printStackTrace(); } System.out.println("所有均完毕"); } } class Task implements Callable{ public Integer call() throws Exception { System.out.println("子线程计算开始"); Thread.sleep(3000); int sum = 0; for (int i=0;i<100000;i++){ sum += i ; } System.out.println("子线程已经计算完毕"); return sum; } } class NewTask implements Callable{ public String call() throws Exception { System.out.println("第二个子线程已经运行完毕"); return "success"; } } 另: 如果main主线程不去获取子线程的结果,那么主线程完全可以不阻塞。那么,此时,主线程和子线程完全异步。此功能,可以做成类似MQ消息中间件之类的,消息异步进行发送。
链接帖子
意见的链接
分享到其他网站

黑客攻防讨论组

黑客攻防讨论组

    You don't have permission to chat.
    • 最近浏览   0位会员

      • 没有会员查看此页面。
    ×
    ×
    • 创建新的...