1.ReentrantLock的简单使用  

Reentrant n.再进入

ReentrantLock 一个可重入互斥Lock具有与使用synchronized方法和语句访问的隐式监视锁相同的基本行为和语义,但具有扩展功能。(从jdk1.8中文版复制而来)

可以完成synchronized相同的作用,但必须手动释放锁

package com.dingyu2;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; /**
* Reentrant n.再进入
* ReentrantLock 一个可重入互斥Lock具有与使用synchronized方法和语句访问的隐式监视锁相同的基本行为和语义,但具有扩展功能。(从jdk1.8中文版复制而来)
* 可以完成synchronized相同的作用,但必须手动释放锁
* @author dingyu
*
*/
public class ReentrantLock1 {
private Lock lock = new ReentrantLock(); public void m1() {
try {
lock.lock();//synchronized(this)类似,锁定的是堆的对象
for (int i = 0; i < 10; i++)
System.out.println("m1-" + i);
} catch (Exception e) {
System.out.println("m1启动"); } finally {
System.out.println("m1结束");
lock.unlock();
}
} public void m2() {
try {
lock.lock();
for (int i = 0; i < 10; i++)
System.out.println("m2-" + i); } catch (Exception e) {
System.out.println("m2启动"); } finally {
System.out.println("m2结束");
lock.unlock();
}
} public static void main(String[] args) {
ReentrantLock1 reentrantLock1 = new ReentrantLock1();
new Thread(() -> reentrantLock1.m1()).start();
new Thread(() -> reentrantLock1.m2()).start();
}
}

2.ReentrantLock对synchronized的扩展之tryLock()

package com.dingyu2;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; /**
* ReentrantLock对synchronized的扩展之tryLock()
*
* @author dingyu
*
*/
public class ReentrantLock2 {
private Lock lock = new ReentrantLock(); public void m1() {
lock.lock();// 一直锁着,不手动释放, 和synchronized(this)类似,锁定的是堆的对象
} public void m2() {
boolean isNotLock = lock.tryLock();// 如果别的进程锁着就返回false,如果没锁返回true
// 我们可以根据有没有锁来执行自己的逻辑,而不需要等着锁的释放,更加灵活
if (isNotLock) {
System.out.println("lock对象没有被锁定");
} else {
System.out.println("lock对象被锁定了");
}
} public static void main(String[] args) {
ReentrantLock2 reentrantLock2 = new ReentrantLock2();
new Thread(() -> reentrantLock2.m1()).start();
new Thread(() -> reentrantLock2.m2()).start();
}
}

3.ReentranLock对synchronized的扩展:可以被另外的线程打断

package com.dingyu2;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; /**
* ReentranLock对synchronized的扩展:可以被另外的线程打断
* 因为m1方法一直占着锁,m2永远不可能得到锁,既然得不到锁,我们就关闭m2好了,这时候得用lockInterruptibly
*
* @author dingyu
*
*/
public class ReentrantLock3 {
private Lock lock = new ReentrantLock(); public void m1() {
lock.lock();
try {
System.out.println("t1 start");
while (true) {
}
} finally {
lock.unlock();
System.out.println("t1 end");
}
} public void m2() {
try {
lock.lockInterruptibly();
System.out.println("t2 start");
} catch (InterruptedException e) {
System.out.println("t2被打断了");
} finally {
if (lock.tryLock())
lock.unlock();
System.out.println("t2 end");
}
} public static void main(String[] args) {
ReentrantLock3 reentrantLock3 = new ReentrantLock3();
Thread t1 = new Thread(() -> reentrantLock3.m1(), "t1");
t1.start();
Thread t2 = new Thread(() -> reentrantLock3.m2(), "t2");
t2.start();
t2.interrupt();
}
}

4.ReentrantLock对synchronized的扩展 : 可以指定公平锁

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; /**
* ReentrantLock对synchronized的扩展 : 可以指定公平锁,哪个线程等待时间长,哪个先执行
* 在构造函数中放入ture参数
*
* @author dingyu
*
*/
public class ReentrantLock4 {
private Lock lock = new ReentrantLock(true); public void m1() {
for (int i = 0; i < 10; i++) {
try {
lock.lock();
System.out.println(Thread.currentThread().getName() + "running");
} finally {
lock.unlock();
}
}
} public static void main(String[] args) {
ReentrantLock4 lock4 = new ReentrantLock4();
new Thread(()->lock4.m1(),"t1").start();
new Thread(()->lock4.m1(),"t2").start();
}
}

5.使用wait和notifyAll实现消费者生产者模式

package com.dingyu2;

import java.util.LinkedList;

/**
* 使用wait和notifyAll实现消费者生产者模式
*
* @author dingyu
*
*/
public class ProduceConsumer {
private final LinkedList<Integer> lists = new LinkedList<Integer>();
private final int MAX = 10;
private int count = 0; public synchronized void put(Integer i) {
while (lists.size() == MAX) { // wait大多数情况和while一起用
try {
this.wait();// 如果满了我就释放锁,并且等待
} catch (InterruptedException e) {
e.printStackTrace();
}
}
lists.add(i);// 生产一个
count++;
this.notifyAll();// 叫醒消费者可以消费啦
} public synchronized Integer get() {
while (lists.size() == 0) {
try {
this.wait();// 如果集合为空,不能消费,释放锁,等着
} catch (InterruptedException e) {
e.printStackTrace();
}
}
Integer num = lists.removeFirst();
count--;
this.notifyAll();// 叫醒生产者,可以继续生产啦
return num;
} }

6.使用Condition 完成生产者消费者模式

package com.dingyu2;
/**
* 使用Condition 完成生产者消费者模式
* @author dingyu
*
*/ import java.util.LinkedList;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; public class ProduceConsumer2 {
private final LinkedList<Integer> lists = new LinkedList<Integer>();
private final int MAX = 10;
private int count = 0; private Lock lock = new ReentrantLock();
private Condition p = lock.newCondition();// 生产者
private Condition c = lock.newCondition();// 消费者 public void put(Integer i) {
try {
lock.lock();
while (lists.size() == MAX) {
try {
p.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
lists.add(i);
count++;
c.signalAll();
} finally {
lock.unlock();
}
} public Integer get() {
Integer i = null;
try {
lock.lock();
while (lists.size() == 0) {
try {
c.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
i = lists.removeFirst();
count++;
p.signalAll();
} finally {
lock.unlock();
}
return i;
} }

7.ThreadLocal 线程局部变量  每个线程中的这个变量归自己线程管

package com.dingyu;

public class ThreadLocal1 {
private ThreadLocal<Integer> tl = new ThreadLocal<Integer>(); public void m1() {
System.out.println(tl.get());
} public void m2() {
tl.set(7898);
} public static void main(String[] args) {
ThreadLocal1 local1 = new ThreadLocal1();
new Thread(() -> local1.m2()).start(); try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
} new Thread(() -> local1.m1()).start();
}
}

Java马士兵高并发编程视频学习笔记(二)的更多相关文章

  1. Java马士兵高并发编程视频学习笔记(一)

    1.同一个资源,同步和非同步的方法可以同时调用 package com.dingyu; public class Y { public synchronized void m1() { System. ...

  2. 《Java虚拟机并发编程》学习笔记

    对<Java虚拟机并发编程>这本书真的是相见恨晚.以前对并发编程只是懂个皮毛,这本书让我对并发编程有了一个全新的认识.所以把书上的知识点做下笔记,以便以后复习使用. 并发与并行 仔细说来, ...

  3. java 多线程——并发编程模型 学习笔记

                                                                                                 并发编程模型 ...

  4. Java并发编程实战 读书笔记(二)

    关于发布和逸出 并发编程实践中,this引用逃逸("this"escape)是指对象还没有构造完成,它的this引用就被发布出去了.这是危及到线程安全的,因为其他线程有可能通过这个 ...

  5. 《Java并发编程的艺术》第4章 Java并发编程基础 ——学习笔记

    参考https://www.cnblogs.com/lilinzhiyu/p/8086235.html 4.1 线程简介 进程:操作系统在运行一个程序时,会为其创建一个进程. 线程:是进程的一个执行单 ...

  6. 《实战Java高并发程序设计》读书笔记二

    第二章  Java并行程序基础 1.线程的基本操作 线程:进程是线程的容器,线程是轻量级进程,是程序执行的最小单位,使用多线程而不用多进程去进行并发程序设计是因为线程间的切换和调度的成本远远的小于进程 ...

  7. Go语言并发与并行学习笔记(二)

    转:http://blog.csdn.net/kjfcpua/article/details/18265461 Go语言的并发和并行 不知道你有没有注意到一个现象,还是这段代码,如果我跑在两个goro ...

  8. java高并发编程(一)

    读马士兵java高并发编程,引用他的代码,做个记录. 一.分析下面程序输出: /** * 分析一下这个程序的输出 * @author mashibing */ package yxxy.c_005; ...

  9. Java 面试知识点解析(二)——高并发编程篇

    前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...

随机推荐

  1. TDD:什么是桩(stub)和模拟(mock)?

    背景 本文假设你对TDD.Stub和Mock已经有了初步的认识,本文简单解释一下stub和mock的区别和使用场景,先看看他们之间的关系: 由上图可以知道mock框架可以非常容易的开发stub和moc ...

  2. 亲子编程玩Micro:bit-动力小车“麦昆”

    少儿编程之风已经吹进各大城市,编程猫.乐博机器人.童程童美等专业培训机构逐渐进入大家的视野,年龄段已经从K12逐渐降低到幼儿园中班.其实,少儿编程的门槛并不高,它不会让孩子一上手就去接触代码,而是会通 ...

  3. jenkins在windows服务器上执行含git push命令的脚本权限不足的解决方法

    错误摘要 默认情况下执行脚本是没问题的,但是脚本中含有git push命令就无法执行了 用jenkins部署hexo博客时候遇到的,执行hexo d -g一直阻塞至Build was aborted, ...

  4. 对js中闭包,作用域,原型的理解

    前几天,和朋友聊天,聊到一些js的基础的时候,有一种‘好像知道,好像又不不知道怎么讲的感觉’...于是捡起书,自己理一理,欢迎拍砖. 闭包 理解闭包首先要理解,js垃圾回收机制,也就是当一个函数被执行 ...

  5. 第41节:Java当中的类集框架

    Java当中的类集框架 类集框架,那么什么是类集框架,集合的种类有哪些,类集框架的基础结构. 类集框架是一组类和接口的集合,位于java.util包当中,是用来用户存储和管理对象的,在这个类集合框架中 ...

  6. 一个需求认识CSS3 的transform-origin属性

    最近遇到一个需求,是以前做PHP的同事问我的问题    下面是他在百度发的问题截图 根据上面的截图,我稍微梳理了一下 问题:现在有个div,旋转45度后,这个div的宽度会动态改变,并且要向右上方偏移 ...

  7. while(true)应用之 实现自己的消息队列

    早些时候,一直有个疑问,就是比如你从前端发一个操作之后,后台为什么能够及时处理你的东西呢?当然了,我说的不是,服务器为什么能够立即接收到你的请求之类高大上的东西.而是,假设你用异步去做一个事情,而后台 ...

  8. GDB dump mem example和命令

    使用方法: You can use the commands dump, append, and restore to copy data between target memory and a fi ...

  9. [P5162] WD与积木

    每种堆法(理解成名次序列,举例3,3,8,2和7,7,100,2都对应2,2,1,3这个名次序列)等概率出现:题目中"两种堆法不同当且仅当某个积木在两种堆法中处于不同的层中"可见这 ...

  10. Java高阶回调,回调函数的另一种玩法

    工具类package com.sctek; import java.lang.reflect.Field; import android.os.CountDownTimer;import androi ...