第3章 JDK并发包(二)】的更多相关文章

JDK并发包二 线程复用--线程池 在线程池中,总有那么几个活跃的线程,当程序需要线程时可以从池子中随便拿一个控线程,当程序执行完毕,线程不关闭,而是将这个线程退会到池子,等待使用. JDK提供了一套Executor框架,可以有效进行线程控制.ThreadPoolExecutor表示一个线程池,Executors类相当与线程池工厂,通过Executors可以获得一个拥有特定功能的线程池. Executors框架提供了各类线程池,主要有下面工厂方法 public static ExecutorSe…
3.2 线程复用:线程池 一种最为简单的线程创建和回收的方法类似如下代码: new Thread(new Runnable() { @Override public void run() { // do sth. } }).start(); 在run方法结束后,自动回收. 在真实的生产环境中,系统由于真实环境的需要,可能会开启很多线程来支撑其应用.而当线程数量过大时,反而会耗尽CPU和内存资源. 3.2.1 什么是线程池 为了避免系统频繁地创建和销毁线程,我们可以让创建的线程进行复用. 在使用线…
3.1.2 重入锁的好搭档:Condition条件 它和wait()和notify()方法的作用是大致相同的.但是wait()和notify()方法是和synchronized关键字合作使用的,而Condition是与重入锁相关联的.通过Lock接口的Condition newCondition()方法可以生成一个与当前重入锁绑定的Condition实例.利用Condition对象,我们就可以让线程在合适的时间等待,或者在某一种特定的时刻得到通知,继续执行. Condition接口提供的基本方法…
3.3 不要重复发明轮子:JDK的并发容器 3.3.1 超好用的工具类:并发集合简介 JDK提供的这些容器大部分在java.util.concurrent包中. ConcurrentHashMap:这是一个高效的并发HashMap.可以理解为一个线程安全的HashMap. CopyOnWriteArrayList:这是一个List,从名字看就是和ArrayList是一族的.在读多写少的场合,这个List的性能非常好,远远好于Vector. ConcurrentLinkedQueue:高效的并发队…
3.2.5 自定义线程创建:ThreadFactory 线程池的主要作用是为了线程复用,也就是避免了线程的频繁创建. ThreadFactory是一个接口,它只有一个方法,用来创建线程: Thread newThread(Runnable r); 当线程池需要新建线程时,就会调用这个方法. 下面的案例使用自定义的ThreadFactory,一方面记录了线程的创建,另一方面将所有的线程都设置为守护线程,这样,当主线程退出后,将会强制销毁线程池. public static void main(St…
3.1 多线程的团队协作:同步控制 3.1.1 synchronized的功能扩展:重入锁 重入锁可以完全替代synchronized关键字. 重入锁使用java.util.concurrent.locks.ReentrantLock类来实现.下面是一段最简单的重入锁使用案例: public class ReenterLock implements Runnable { public static ReentrantLock lock = new ReentrantLock(); public…
一,JDK并发包实际上就是指java.util.concurrent包里面的那些类和接口等 主要分为以下几类: 1,原子量:2,并发集合:3,同步器:4,可重入锁:5,线程池 二,原子量 原子变量主要有AtomicInteger,AtomicLong,AtomicBoolean等, 主要实现原理都是底层实现类CAS 即比较并交换,都有get,set,compareAndSet等方法,如++,--等也都是有自带方法实现 这些都是线程安全的,保证了多线程访问时候的可见性 import java.ut…
JDK并发包之同步控制 一.重入锁 重入锁使用java.util.concurrent.locks.ReentrantLock来实现.示例代码如下: public class TryReentrantLock implements Runnable{ static ReentrantLock lock=new ReentrantLock(); static int i=0; @Override public void run() { for(int j=0;j<10000;j++){ lock.…
JDK内部提供了大量实用的API和框架.本章主要介绍这些JDK内部功能,主要分为3大部分: 首先,介绍有关同步控制的工具,之前介绍的synchronized就是一种同步控制手段,将介绍更加丰富的多线程控制方法. 其次,将详细介绍JDK对线程池的支持,使用线程池,将很大程度提高线程调度的性能. 第三,介绍JDK的一些并发容器.这些容器专为并行访问所设计,绝对是高效.安全.稳定的实用工具. 多线程团队协作:同步控制 之前提到的synchronized是最简单的同步控制的方法.本节中,首先介绍sync…
web前端学习python之第一章_基础语法(二) 前言:最近新做了一个管理系统,前端已经基本完成, 但是后端人手不足没人给我写接口,自力更生丰衣足食, 所以决定自学python自己给自己写接口哈哈哈哈- 上一章内容:web前端学习python之第一章_基础语法(一) 函数的定义和使用 内置函数 python有很多内置的有用的函数,可以直接调用,参考网址:https://docs.python.org/3/library/functions.html#abs 数据类型转换 其他数据类型转为整数i…