前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java线程池

Java线程池

作者头像
sparkle123
发布2018-04-28 15:34:47
8750
发布2018-04-28 15:34:47
举报
文章被收录于专栏:大数据-Hadoop、Spark

CallableRunable都是启动一个线程, 不过Callable可以有返回值

代码语言:javascript
复制
import java.util.concurrent.{Callable, Executor, Executors, Future}

object ThreadDemo {

  def main(args: Array[String]): Unit = {

    val pool = Executors.newFixedThreadPool(5)

//    for(i <- 1 to 10) {
//      pool.execute(new Runnable {
//        override def run(): Unit = {
//          println(Thread.currentThread().getName)
//          Thread.sleep(1000)
//        }
//      })
//    }

    //开启子线程
    val f :Future[Int] = pool.submit(new Callable[Int] {
      override def call(): Int = {
        Thread.currentThread().getName
        //返回100
        100
      }
    })

    var status = f.isDone
    println(s"task status : $status")

    Thread.sleep(5000)

    status = f.isDone
    println(s"task status : $status")

    //status == true的时候,取出子线程返回值:100
    if(status){
      println(f.get())
    }
  }
}

结果:

代码语言:javascript
复制
task status : false
task status : true
100
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.04.24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档