//测试的线程                                                           
public class Record implements Runnable {                         
                                                                  
    public int countDown = 10;                                    
    private static int taskCount = 0;                             
    private final int id = taskCount++;                           
                                                                  
    public Record() {                                             
    };                                                            
                                                                  
    public Record(int countDown) {                                
        this.countDown = countDown;                               
    }                                                             
                                                                  
    public String status() {                                      
        return "#" + id + "(" + countDown + "),";                 
    }                                                             
                                                                  
    @Override                                                     
    public void run() {                                           
        while(countDown-- > 0 ){                                  
            System.out.print(status());                           
            Thread.yield();                                       
        }                                                         
    }                                                             
                                                                  
}

=====================main===================

  一、CachedThreadPool 执行类

import java.util.concurrent.ExecutorService;                                  
import java.util.concurrent.Executors;                                        
                                                                              
import com.harry.handler.Record;                                              
                                                                              
public class CachedThreadPoolDemo {                                           
                                                                              
    public static void main(String[] args) {                                  
        //会不断的创建线程,当有已经完成任务的线程出现时会复用原来的线程。                                    
        ExecutorService executor = Executors.newCachedThreadPool();           
        for (int i = 0; i < 5; i++) {                                         
            executor.execute(new Record());                                   
        }                                                                     
        executor.shutdown();                                                  
    }                                                                         
}

二、FixedThreadPool     执行类    

import java.util.concurrent.ExecutorService;                        
import java.util.concurrent.Executors;                              
                                                                    
import com.harry.handler.Record;                                    
                                                                    
public class FixedThreadPoolDemo {                                  
                                                                    
    public static void main(String[] args) {                        
        //首先要设置规定的线程数量。                                             
        ExecutorService exec = Executors.newFixedThreadPool(5);     
        for (int i = 0; i < 5; i++) {                               
            exec.execute(new Record());                             
        }                                                           
        exec.shutdown();                                            
    }                                                               
}

三、SingleThreadPool 执行类    

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

import com.harry.handler.Record;

public class SingleThreadExecutorDemo {

public static void main(String[] args) {
        //相当于线程数量为1的 FixedThreadPool
        
        //如果singleThreadEcecutor提交多个任务。那么这些任务会排队,
        //每个任务都会在下一个任务执行之前运行介绍,所有的任务都共用一个线程。
        ExecutorService exec = Executors.newSingleThreadExecutor();
        for (int i = 0; i < 5; i++) {
            exec.execute(new Record());
        }
        exec.shutdown();
    }
}

Executor类的更多相关文章

  1. MyBatis 源码分析——SqlSession接口和Executor类

    mybatis框架在操作数据的时候,离不开SqlSession接口实例类的作用.可以说SqlSession接口实例是开发过程中打交道最多的一个类.即是DefaultSqlSession类.如果笔者记得 ...

  2. 通过Thread Pool Executor类解析线程池执行任务的核心流程

    摘要:ThreadPoolExecutor是Java线程池中最核心的类之一,它能够保证线程池按照正常的业务逻辑执行任务,并通过原子方式更新线程池每个阶段的状态. 本文分享自华为云社区<[高并发] ...

  3. 转: Executor类

    Executor框架是指java 5中引入的一系列并发库中与executor相关的一些功能类,其中包括线程池,Executor,Executors,ExecutorService,Completion ...

  4. 【并发编程】Executor类的继承结构

    来自为知笔记(Wiz)

  5. Spark源码学习1.6——Executor.scala

    Executor.scala 一.Executor类 首先判断本地性,获取slaves的host name(不是IP或者host: port),匹配运行环境为集群或者本地.如果不是本地执行,需要启动一 ...

  6. Java线程池的原理及几类线程池的介绍

    刚刚研究了一下线程池,如果有不足之处,请大家不吝赐教,大家共同学习.共同交流. 在什么情况下使用线程池? 单个任务处理的时间比较短 将需处理的任务的数量大 使用线程池的好处: 减少在创建和销毁线程上所 ...

  7. 多线程之线程池Executor应用

    JDK1.5之后,提供了自带的线程池,以便我们更好的处理线程并发问题. Executor类给我提供了多个线程池创建的方式: 创建固定的线程池 Executors.newFixedThreadPool( ...

  8. java并发编程框架 Executor ExecutorService invokeall

    首先介绍两个重要的接口,Executor和ExecutorService,定义如下: public interface Executor { void execute(Runnable command ...

  9. Java线程池 Executor框架概述

    线程池的意义 循环利用线程资源,避免重复创建和销毁线程 线程池的任务是异步执行的,只要提交完成就能快速返回,可以提高应用响应性 Java线程池还有一个很重要的意义:Java线程池就是JDK 5 推出的 ...

随机推荐

  1. thinkphp之无限分类

    namespace Home\Controller; use Home\Controller; class CategoryController extends Controller { //无限分类 ...

  2. 《我想进大厂》之Java基础夺命连环16问

    说好了面试系列已经完结了,结果发现还是真香,嗯,以为我发现我的Java基础都没写,所以这个就算作续集了,续集第一篇请各位收好. 说说进程和线程的区别? 进程是程序的一次执行,是系统进行资源分配和调度的 ...

  3. AHB SRAM控制器设计

  4. 与pandas初相识

    前一阵子有个同事说,他看不懂从kibana上拉下来的日志,但是又想分析一些数据,感觉很头痛,每次都找开发给他整理一下,但是开发也很忙,要数据的频率也略高,那时候正好我跟这位需求方的项目,负责测试工作. ...

  5. docker生产——容器通信

    简介 在接触docker的第一天起,大家应该就知道:docker容器使用沙箱机制,相互之间没有接口,一般情况下内部访问通过IP+端口.本地容器默认分配的IP极易发生变化,所以靠IP+端口访问的方式缺失 ...

  6. python文件操作与编解码

    1 # 文件操作 2 3 ''' 4 1.文件路径:要知道文件的路径 5 6 2.编码方式:要知道文件是什么编码的.utf-8 gbk...... 7 8 3.操作方式:要以什么样的方式进行打开这个文 ...

  7. SNMP介绍及使用,超有用,建议收藏!

    写在前面 如果你是对SNMP完全不了解,或者只想学习如何使用现成的SNMP工具,那你找对了文章,但如果你希望学习SNMP具体协议内容,推荐阅读官方的RFC文档. 1. 简介 SNMP(Simple N ...

  8. 保证看完就会!大数据YRAN核心知识点来袭!

    01 我们一起学大数据 大家好,今天分享的是大数据YRAN的核心知识点,老刘尽量用通俗易懂的话来讲述YARN知识点,争取做到大家看完后能够用口语化的形式将它们表达出来,做到真正的看完就会!(如果觉得老 ...

  9. 使用python统计《三国演义》小说里人物出现次数前十名,并实现可视化。

    一.安装所需要的第三方库 jieba (jieba是优秀的中文分词第三分库) pyecharts (一个优秀的数据可视化库) <三国演义>.txt下载地址(提取码:kist ) 使用pyc ...

  10. 在Guitar Pro中如何模拟电子管音响

    在这篇文章中,我们将使用Guitar Pro 7中的功能和工具,完成构建一个真实的电子管吉他音箱调音过程. 虽然Guitar Pro是用于创建吉他乐谱的工具,但在新版本中(主要是6和7)它也有一些模拟 ...