本章主要讲并发线程的常见的两种锁.重入锁和读写锁 一:重入锁(ReentrantLock) 概念:重入锁,在需要进行同步的代码加锁,但最后一定不要忘记释放锁,否则会造成锁永远不能释放,其他线程进不了 代码解析: 1 实例化:Lock lock = new ReentrantLock(); 2 3 锁定:lock .lock(); 4 5 释放锁:lock.unlock(); 代码: 1 private Lock lock = new ReentrantLock(); 2 3 public voi…
本章主要记录讲解并发线程的线程池.java.util.concurrent工具包里面的工具类. 一:Executor框架: Executors创建线程池的方法: newFixedThreadPool()方法: 该方法返回一个固定数量的线程池,该方法的线程数始终不变,当有一个任务提交时,若线程池中空闲,则立即执行,若没有,则会被暂缓在一个任务队列中等待有空闲的线程去执行. newSingleThreadExecutor()方法:创建一个线程的线程池,若空闲则执行.若没有,则暂缓在任务队列中. ne…
本章主要记录讲解并发线程的线程池.使用Executor框架自定义线程池. 自定义线程池使用Queue队列所表示出来的形式: 1 ArrayBlockingQueue<Runnable>(3); 有界队列: 2 3 /** 4 * 在使用有界队列时,若有新的任务需要执行,如果线程池实际线程数小于corePoolSize,则优先创建线程, 5 * 若大于corePoolSize,则会将任务加入队列, 6 * 若队列已满,则在总线程数不大于maximumPoolSize的前提下,创建新的线程, 7…
本章主要介绍和讲解concurrent.util里面的常用的工具类. 一.CountDownLatch使用:(用于阻塞主线程) 应用场景 :通知线程休眠和运行的工具类,是wait和notify的升级版本.notify不会释放锁,但是  countDown()会释放锁 实例化:final CountDownLatch countDown = new CountDownLatch(2); 使用在Thread里面: countDownLatch.countDown(); 相当于 notfiy: 特点:…
Java高并发 -- 线程池 主要是学习慕课网实战视频<Java并发编程入门与高并发面试>的笔记 在使用线程池后,创建线程变成了从线程池里获得空闲线程,关闭线程变成了将线程归坏给线程池. JDK有一套Executor框架,大概包括Executor.ExecutorService.AbstractExeccutorService.ThreadPoolExecutor.Executors等成员,位于java.util.concurrent包下.它们之间的关系如下: Executor是顶层的接口,E…
Java高并发--线程安全策略 主要是学习慕课网实战视频<Java并发编程入门与高并发面试>的笔记 不可变对象 发布不可变对象可保证线程安全. 实现不可变对象有哪些要注意的地方?比如JDK中的String类. 不提供setter方法(包括修改字段.字段引用到的的对象等方法) 将所有字段设置为final.private 将类修饰为final,不允许子类继承.重写方法.可以将构造函数设为private,通过工厂方法创建. 如果类的字段是对可变对象的引用,不允许修改被引用对象. 1)不提供修改可变对…
作者:汤圆 个人博客:javalover.cc 前言 前面我们在创建线程时,都是直接new Thread(): 这样短期来看是没有问题的,但是一旦业务量增长,线程数过多,就有可能导致内存异常OOM,CPU爆满等问题 幸运的是,Java里面有线程池的概念,而线程池的核心框架,就是我们今天的主题,Executor 接下来,就让我们一起畅游在Java线程池的海洋中吧 本节会用银行办业务的场景来对比介绍线程池的核心概念,这样理解起来会很轻松 简介 Executor是线程池的核心框架: 和它相对应的有一个…
今天,我们开始Java高并发与多线程的第四篇,锁. 之前的三篇,基本上都是在讲一些概念性和基础性的东西,东西有点零碎,但是像文科科目一样,记住就好了. 但是本篇是高并发里面真正的基石,需要大量的理解和实践,一环扣一环,环环相扣,不难,但是需要认真去读. 好了,现在开始. --------------第一部分,咱们要谈到java里面的两个用于保证线程之间有序性的关键字-------------- [synchronized] synchronized是Java中解决并发问题的一种最常用的方法,也是…
import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.concurrent.ThreadPoolExecutor; /** * 创建线程的方式四:使用线程池 * * 好处: * 1.提高响应速度(减少了创建新线程的时间) * 2.降低资源消耗(重复利用线程池中线程,不需要每次都创建) * 3.便于线程管理 * corePoolSize:核心池的大小 *…
java多线程的三大设计模式 本章主要记录java常见的三大设计模式,Future.Master-Worker和生产者-消费者模式. 一.Future模式 使用场景:数据可以不及时返回,到下一次实际要使用结果的之前,后台自动查询并返回.类似与Ajax异步加载. 原理:客户端发起请求,结果需要返回Data对象,当服务器收到请求以后,FutureData包装类实现Data接口,不查询数据库,直接返回结果.(核心).然后后台自己开一个线程去查询数据库,RealData真 实数据类,也实现Data接口,…