JDK1.5多线程提高

1.名词:

  1.任务的执行与任务的提交解耦

  2.任务的执行策略-可中断,取消

2.线程封闭机制:

  针对单线程池而言,提高任务执行的速度,但是无需锁定

3.饥饿死锁:

  任务长期得不到执行,其实就是形成闭合的环路导致,共享资源互相锁定导致

4.超时机制:

  指定时间任务完不成,则重新加入的线程的执行队列中等待重新执行(超时就是重试机制)

5.线程池的大小:

  做好做成动态的,看CPU的线程数:Runntime.avalibleProcessors()

6.ExecutorService:

  线程管理器其实就是一个ThreadPools,里面有线程,任务队列所以我们可以定制ThreadPoolsExecutor(个数,最大个数,空闲时间,任务队列,线程工厂,拒绝处理器

  空闲时间:线程没有被执行的时间间隔,如果一直未被使用,则进行回收

  任务队列:用户提交的任务列表,其实就是缓存,等待线程执行---扩展点

  线程工厂:  线程池随着需求进行动态创建线程的过程中所使用的线程工厂  ----扩展点

  拒绝策略:针对用户提交任务的限制,因为队列是优先的---扩展点

  线程工厂:定制特殊的线程

  线程池:任务执行前后进行监控 beforeExecute  afterExecute

7.队列:

  有届队列:大小有限制,超过容量之后将会执行拒绝的执行器

  无界队列:

  同步移交:针对大队列,直接提交给执行线程

8.Caller-Run:一种饱和机制,任务执行在与Executor的所在线程,应用层进行排队执

9.控制线程池的任务提交的速率就是通过信号量机制进行限制

10.守护线程与非守护线程:

11.

JDK1.5多线程提高

时间: 2024-08-07 00:07:47

JDK1.5多线程提高的相关文章

[.net 面向对象程序设计进阶] (16) 多线程(Multithreading)(一) 使用多线程提高程序性能

[.net 面向对象程序设计进阶] (16) 多线程(Multithreading)(一) 使用多线程提高程序性能 本节导读: 多线程(Multithreading)使我们程序可以同时进行多任务处理,直接提高了程序的执行效率,学习多线程对提高程序运行能力非常必要,本节主要介绍多线程原理及.NET中多线程的应用. 1. 关于多线程 在介绍多线程之前,先了解一下进程. 进程:独立运行的程序称为进程.(比如Windows系统后台程序,也可以称为后台进程) 线程:对于同一个程序分为多个执行流,称为线程.

[.net 面向对象程序设计进阶] (18) 多线程(Multithreading)(三) 利用多线程提高程序性能(下)

[.net 面向对象程序设计进阶] (18) 多线程(Multithreading)(二) 利用多线程提高程序性能(下) 本节导读: 上节说了线程同步中使用线程锁和线程通知的方式来处理资源共享问题,这些是多线程的基本原理. .NET 4.0以后对多线程的实现变得更简单了. 本节主要讨论.NET4.0多线程的新特性——使用Task类创建多线程. 读前必备: A. LINQ使用  [.net 面向对象编程基础] (20) LINQ使用 B. 泛型          [.net 面向对象编程基础] (

JAVA多线程提高六:java5线程并发库的应用_线程池

前面我们对并发有了一定的认识,并且知道如何创建线程,创建线程主要依靠的是Thread 的类来完成的,那么有什么缺陷呢?如何解决? 一.对比new Threadnew Thread的弊端 a. 每次new Thread新建对象性能差. b. 线程缺乏统一管理,可能无限制新建线程,相互之间竞争,及可能占用过多系统资源导致死机或oom. c. 缺乏更多功能,如定时执行.定期执行.线程中断.相比new Thread,Java提供的四种线程池的好处在于:a. 重用存在的线程,减少对象创建.消亡的开销,性能

JAVA多线程提高十:同步工具CyclicBarrier与CountDownLatch

今天继续学习其它的同步工具:CyclicBarrier与CountDownLatch 一.CyclicBarrier CyclicBarrier是一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point).在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时 CyclicBarrier 很有用.因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的 barrier. CyclicBarrier类似于CountDownL

JAVA多线程提高十一:同步工具Exchanger

Exchanger可以在对中对元素进行配对和交换的线程的同步点.每个线程将条目上的某个方法呈现给 exchange 方法,与伙伴线程进行匹配,并且在返回时接收其伙伴的对象.Exchanger 可能被视为 SynchronousQueue 的双向形式.Exchanger 可能在应用程序(比如遗传算法和管道设计)中很有用. 构造方法摘要  Exchanger() 创建一个新的 Exchanger. 方法摘要 CountDownLatch CyclicBarrier V exchange(V x) 等

JAVA多线程提高十二:阻塞队列应用

一.类相关属性 接口BlockingQueue<E>定义: public interface BlockingQueue<E> extends Queue<E> { boolean add(E e); boolean offer(E e); void put(E e) throws InterruptedException; boolean offer(E e, long timeout, TimeUnit unit) throws InterruptedExcepti

使用多线程提高REST服务器性能

异步处理REST服务 1.使用Runnable异步处理Rest服务 释放主线程,启用副线程进行处理,副线程处理完成后直接返回请求 主要代码 import java.util.concurrent.Callable; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.RequestMapping; import org.springframe

同步、异步、多线程与事件型综述

转自:http://blog.csdn.net/chszs/article/details/8867174 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs首先要了解什么是阻塞和阻塞式IO.线程在执行中如果遇到磁盘读写或网络通信(统称IO操作),通常要耗费较长的时间,这时操作系统会剥夺此线程的CPU控制权,使其暂停执行,同时将资源让给其他的工作线程,这种线程调度方式称为阻塞.当IO操作完毕时,操作系统将这个线程的阻塞状态解除,恢复其对CPU的控制权,令

Python多线程、进程入门1

进程是资源的一个集合, 1.一个应用程序,可以有多进程和多线程 2.默认一个程序是单进程单线程 IO操作使用多线程提高并发 计算操作使用多进程提高并发 进程与线程区别 1.线程共享内存空间,进程的内存是独立的 2.线程共享进程内存的数据,进程之间的数据是无法进行访问的 3.在同一个进程内,线程之间可以直接进行数据的访问,两个进程如果通信,必须通过一个中间代理进行通信 4.创建线程非常容易,创建新进程需要对其父进程进行一次克隆 5.一个线程可以控制和操作同一进程里的其它线程,但是进程只能操作子进程