JDK1.5 Excutor 与ThreadFactory】的更多相关文章

Excutor 源码解读: /** * An object that executes submitted {@link Runnable} tasks. This * interface provides a way of decoupling task submission from the * mechanics of how each task will be run, including details of thread * use, scheduling, etc. An {@co…
概述 Excutor这个接口用的不多,但是ThreadPoolExcutor这个就用的比较多了,ThreadPoolExcutor是Excutor的一个实现.Excutor体系难点没有,大部分的关键点和设计思路都在javadoc中描述的特别详细,但有必要做一下梳理,以便在后续开发场景中,更好地使用jdk提供的灵活的api. Excutor接口主要用于解耦任务执行者和任务发起者,jdk8的javadoc写的非常详细.因此,Excutor这个系列的类都冲着这个目标来实现,当然,很多实现类更是在特定的…
一.什么是线程池 为什么要使用线程池?在多线程并发开发中,线程的数量较多,且每个线程执行一定的时间后就结束了,下一个线程任务到来还需要重新创建线程,这样线程数量特别庞大的时候,频繁的创建线程和销毁线程需要一定时间而且增加系统的额外开销.基于这样的场景,线程池就出现了,线程池可以做到一个线程的任务处理完可以接受下一个任务,并不需要频繁的创建销毁,这样大大节省了时间和系统的开销. 线程池,顾名思义,就是一个池子,任务提交的到线程池后,线程池会在池子里边找有没有空闲的线程,如果没有,就会进入等待状态,…
ThreadFactory翻译过来是线程工厂,顾名思义,就是用来创建线程的,它用到了工厂模式的思想.它通常和线程池一起使用,主要用来控制创建新线程时的一些行为,比如设置线程的优先级,名字等等.它是一个接口,接口中只有一个方法: /* * * * * * * Written by Doug Lea with assistance from members of JCP JSR-166 * Expert Group and released to the public domain, as expl…
概述 Excutor这个接口用的不多,但是ThreadPoolExcutor这个就用的比较多了,ThreadPoolExcutor是Excutor的一个实现.Excutor体系难点没有,大部分的关键点和设计思路都在javadoc中描述的特别详细,但有必要做一下梳理,以便在后续开发场景中,更好地使用jdk提供的灵活的api. Excutor接口主要用于解耦任务执行者和任务发起者,jdk8的javadoc写的非常详细.因此,Excutor这个系列的类都冲着这个目标来实现,当然,很多实现类更是在特定的…
JDK1. 7中的ThreadPoolExecutor 线程池,顾名思义一个线程的池子,池子里存放了非常多能够复用的线程,假设不用线程池相似的容器,每当我们须要创建新的线程时都须要去new Thread(),用完之后就被回收了,线程的启动回收都须要用户态到内核态的交互,频繁的创建开销比較大.而且随着线程数的增加,会引起CPU频繁的上下文切换严重影响性能. 这时候线程池相似的容器就发挥出了作用.线程池里面的线程不但能够复用,而且还能够控制线程并发的数量,是CPU的性能达到最优.以下一点一点的分析一…
注:以下所有操作均在CentOS 6.5 x86_64位系统下完成. #准备工作# 准备用rpm下载前,看系统是否已经安装有JDK,如果没有则进入正式安装步骤. # rpm -qa | grep jdk 首先需要去下载JDK-1.7,我们选择去官网下载.但这里在下载的时候有点麻烦,默认的下载路径是没办法直接使用wget命令下载的,有个方法是: 1)进入Oracle的官网,比如:http://www.oracle.com/technetwork/java/javase/downloads/jdk7…
自己在Ubuntu中安装jdk1.8的步骤,记录以方便以后查询. 将下载好的jdk安装包移到/usr/local目录中(我喜欢将自己安装的软件放在/usr/local目录中),解压缩 sudo tar xzvf jdk-8u60-linux-x64.tar.gz 2.  删除压缩包 sudo rm jdk-8u60-linux-x64.tar.gz 3.  将以下路径添加到/etc/environment文件中 PATH="/usr/local/sbin:/usr/local/bin:/usr/…
首先说明下我的主机环境:主机:32位win7 虚拟机:VMware Workstation10.0.1 linux:红帽子centos6.4 jdk1.7 Apache-tomcat7 java环境需要有jdk,第一步要先安装jdk Jdk的安装 1.解压或安装 .gz包 #tar -zxvf jdk-7u9-linux-i586.tar.gz 解压后的目录如:jdk1.7.0_09 将其复制或移动到/usr目录下 #mv jdk1.7.0_09 /usr .rpm包 #rpm -ivh jdk…
1.安装JDK1.7 (1)下载 官网下载路径:http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads-1880260.html 选择适合自己的版本下载. (2)安装解压即可…