欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Java线程池的应用实例分析

时间:2021-09-05 09:44:23|栏目:JAVA代码|点击:

本文实例讲述了Java线程池的应用。分享给大家供大家参考,具体如下:

一 使用Future与Callable来计算斐波那契数列

1 代码

import java.util.concurrent.*;
public class FutureCallableDemo
{
  static long fibonacci(long n)
  {
    if (n == 1 ||n == 2)
      return 1;
    else
      return fibonacci(n - 1) + fibonacci(n - 2);
  }
  public static void main( String[] args) throws Exception
  {
    Callable<Long> task = () -> fibonacci(30);
    ExecutorService executor = Executors.newFixedThreadPool(1);
    Future<Long> future = executor.submit(task);
    System.out.println("计算第10个斐波那契级数,过会来取...") ;
    while (future.isDone() == false)
    {
      System.out.println("忙别的去吧,结果还在计算中...") ;
    }
    System.out.printf("计算完毕,第10个斐波那契级数是:%d %n", future.get()) ;
  }
}

2 运行

计算第10个斐波那契级数,过会来取...
忙别的去吧,结果还在计算中...
忙别的去吧,结果还在计算中...
忙别的去吧,结果还在计算中...
忙别的去吧,结果还在计算中...
忙别的去吧,结果还在计算中...
......
忙别的去吧,结果还在计算中...
计算完毕,第10个斐波那契级数是:832040

二 线程池模拟工人做工

1 代码

import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
class Task implements Runnable
{
  private String name;
  public Task(String name)
  {
    this.name = name;
  }
  public String getName() {
    return name;
  }
  @Override
  public void run()
  {
    try
    {
      Long duration = (long) (Math.random() * 100);
      System.out.println("正在做工中,执行者 : " + name);
      TimeUnit.SECONDS.sleep(duration);
    }
    catch (InterruptedException e)
    {
      e.printStackTrace();
    }
  }
}
public class BasicThreadPoolExecutorExample
{
  public static void main(String[] args)
  {
    ThreadPoolExecutor executor = (ThreadPoolExecutor) Executors.newCachedThreadPool();
    for (int i = 0; i <= 5; i++)
    {
      Task task = new Task("Task " + i);
      System.out.println("新任务添加成功 : " + task.getName());
      executor.execute(task);
    }
    executor.shutdown();
  }
}

2 运行

新任务添加成功 : Task 0
新任务添加成功 : Task 1
新任务添加成功 : Task 2
新任务添加成功 : Task 3
新任务添加成功 : Task 4
新任务添加成功 : Task 5
正在做工中,执行者 : Task 0
正在做工中,执行者 : Task 3
正在做工中,执行者 : Task 1
正在做工中,执行者 : Task 2
正在做工中,执行者 : Task 4
正在做工中,执行者 : Task 5
 
Process finished with exit code 0

更多java相关内容感兴趣的读者可查看本站专题:《Java进程与线程操作技巧总结》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总

希望本文所述对大家java程序设计有所帮助。

上一篇:详解spring-boot集成elasticsearch及其简单应用

栏    目:JAVA代码

下一篇:Java定义形式及可变参数实例解析

本文标题:Java线程池的应用实例分析

本文地址:http://www.codeinn.net/misctech/172598.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有