Java 线程池和普通线程区别

本贴最后更新于 2853 天前,其中的信息可能已经时移世易

Java 中线程池和原生线程貌似有点不一样,求解答。。。
下面附上两个 Demo 完成的功能是主线程等待所有子线程结束然后统计总耗时,第一个使用了线程池,第二个使用 Java 原生线程。

示例一:

import java.util.LinkedList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
* Created on 2016/11/25 * * @author annpeter.it@gmail.com
*/public class Bootstrap {
 private static ExecutorService executorService = Executors.newFixedThreadPool(10);
private static List list = new LinkedList<>();
private static Random random = new Random();

public static void main(String[] args) throws InterruptedException {
     long from = System.currentTimeMillis();

for (int i = 0; i < 10; i++) {
         final int index = i;
Runnable runnable = () -> {
             try {
                 int time = random.nextInt(5000);
Thread.sleep(time);
System.out.println("i = " + index + " sleep: " + time);
} catch (InterruptedException ignored) {
                 // passed
}
         };

Thread thread = new Thread(runnable);

executorService.execute(thread);
list.add(thread);
}

     for (Thread thread : list) {
         System.out.println(thread.isAlive());
thread.join();
}

     long to = System.currentTimeMillis();
System.out.println("总用时: " + (to - from) );
}
}

示例二:

import java.util.LinkedList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
* Created on 2016/11/25 * * @author annpeter.it@gmail.com
*/public class Bootstrap {
  private static List list = new LinkedList<>();
private static Random random = new Random();

public static void main(String[] args) throws InterruptedException {
      long from = System.currentTimeMillis();

for (int i = 0; i < 10; i++) {
          final int index = i;
Runnable runnable = () -> {
              try {
                  int time = random.nextInt(5000);
Thread.sleep(time);
System.out.println("i = " + index + " sleep: " + time);
} catch (InterruptedException ignored) {
                  // passed
}
          };

Thread thread = new Thread(runnable);
thread.start();
list.add(thread);
}

      for (Thread thread : list) {
          System.out.println(thread.isAlive());
thread.join();
}

      long to = System.currentTimeMillis();
System.out.println("总用时: " + (to - from) );
}
}
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3170 引用 • 8209 回帖 • 1 关注
  • Thread
    3 引用 • 24 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • jonwinters 2

    线程池主要是为了解决 大规模应用中线程复用的问题,因为创建线程,需要重新创建线程上下文 以及堆栈 PC 之类的,线程本身就是非常昂贵的资源开销,
    每一个新的线程都对应自己的线程栈,而且 Java 在 GC 的时候 需要暂停所有线程(不同 JVM 有自己的实现,这个不是绝对的),标记对象 进行回收,如果线程过多,GC 的时间就会相应增加 ,
    目前广泛采用的 GC root 算法,也就是针对所有的对象,形成一个无向图,然后进行一个图的搜索,如果所有线程的 当前 堆栈 本地方法栈 等都没有引用到这个对象的时候,这个对象就会被标记回收,

    小规模运用的话,用不用线程池 区别不大,因为创建线程开销相对较小,如果是亿级别的访问量,试问 tomcat 针对每一个 request 请求都进行一个线程创建,
    开销是十分巨大的,所以一般会采用动态线程池,根据并发访问量 来自动扩充工作线程。

    如果你的并发以及访问压力不大,例如一个手指头都 能搞定的话,线程池只是大材小用,如果并发量相当大的话,一般都会使用线程池

  • 其他回帖
  • 88250

    我想暗示的是他姿势不对,导致了 join 没作用

    2 回复
  • jonwinters

    另外楼主还要去补一补常见的 IO 模型,补完 IO 模型,你大概就能理解为什么要使用线程池了,

  • mainlove 1

    lz 这样的测试意义不大
    lz 先去搜索下线程池解决了什么问题,然后再去测试,lz 这样测试说明了什么问题?好像看不出。。。

  • 查看全部回帖

推荐标签 标签

  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 561 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    28 引用 • 66 回帖 • 2 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    83 引用 • 37 回帖
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    86 引用 • 122 回帖 • 626 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    192 引用 • 511 回帖 • 2 关注
  • 招聘

    哪里都缺人,哪里都不缺人。

    190 引用 • 1056 回帖
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    98 引用 • 344 回帖
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 629 关注
  • IBM

    IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。

    17 引用 • 53 回帖 • 131 关注
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1704 回帖
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    20 引用 • 23 回帖 • 719 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    406 引用 • 3568 回帖
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 624 关注
  • ActiveMQ

    ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

    19 引用 • 13 回帖 • 661 关注
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 8 关注
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    131 引用 • 1114 回帖 • 143 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    10 引用 • 32 回帖 • 107 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 728 关注
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 527 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 695 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    52 引用 • 37 回帖
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    5 引用 • 26 回帖 • 516 关注
  • 国际化

    i18n(其来源是英文单词 internationalization 的首末字符 i 和 n,18 为中间的字符数)是“国际化”的简称。对程序来说,国际化是指在不修改代码的情况下,能根据不同语言及地区显示相应的界面。

    8 引用 • 26 回帖 • 1 关注