Java并发学习(一)

Java并发学习

学习参考链接 B站-黑马并发课程

一 入门

  1. 进程与线程的对比
    在这里插入图片描述
  2. 并发与并行
  • 并发
    并发
  • 并行
    在这里插入图片描述
  1. Runnable 与Thread的关系
    在这里插入图片描述
  2. 查看指定java进程下的所以线程
  • top -H -p 4901
  • jstack 进程Id 可抓取指定进程的线程快照信息
  • jconsole
  1. 栈帧
    在这里插入图片描述
  2. 常用方法
    在这里插入图片描述
  • sleep: 从RUNNING/RUNNABLE 到 TIMED_WAITING ,再到RUNNABLE;
  • yield: 从RUNNING 到RUNNABLE

在这里插入图片描述
7. 防止CPU占用100%
在这里插入图片描述

  1. join在这里插入图片描述
  2. interrupt
  • sleep wait join的 等处于阻塞状态的线程,打断会抛出异常: 打断标记会被重置为false; 抛出异常;
  • 正常的线程:打断只是给线程添加标记,不会终止线程
    在这里插入图片描述

1.1 设计模式-二阶段终止

  1. 思路
    在这里插入图片描述

在这里插入图片描述
10. park

  • 打断标记为真时,park会失效
  1. 不推荐的方法
    在这里插入图片描述

1.2 主线程与守护线程

在这里插入图片描述
在这里插入图片描述

1.3 线程的状态

  1. 五种状态
    在这里插入图片描述
    在这里插入图片描述2. 六种状态
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

二 共享模型之管程

2.1 线程安全的问题

在这里插入图片描述
2. 临界区
在这里插入图片描述
在这里插入图片描述
3 竞态条件
在这里插入图片描述
4 synchronized解决方案
在这里插入图片描述
在这里插入图片描述
5 synchronized 放在方法上

  • 添加在成员方法上,锁的是this;
  • 添加在静态方法上,锁的是 类对象(Class对象);
    6

    2.2 线程安全分析

    在这里插入图片描述
    2 线程安全的类
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

2.3 Monitor

  1. 对象头
    在这里插入图片描述

  2. Monitor
    在这里插入图片描述
    在这里插入图片描述

  3. 在字节码层面理解synchronized

    在这里插入图片描述

  4. synchronized的锁升级与优化

  • 轻量级锁
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  • 锁膨胀

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
- 自旋优化

自旋在多核CPU的情况下才有意义
在这里插入图片描述
在这里插入图片描述

  • 偏向锁

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 锁消除
    • 参数:-XX:EliminateLocks

2.4 wait-notify

在这里插入图片描述
在这里插入图片描述

所以 wait 和notify方法必须 在同步代码块中进行使用
在这里插入图片描述

  • 相同点:sleep和wait都会让出cpu的使用权;状态都是TIMED_WAITING

在这里插入图片描述

2.4 设计模式-保护性暂停

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

### 2.5 设计模式-异步模式之生产者/消费者

  1. 要点
    在这里插入图片描述

2.5 Park & Unpark

  1. 使用方式
    在这里插入图片描述
    在这里插入图片描述
  2. park的原理
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

2.6 线程状态转换

  1. 重新理解线程状态转换
    在这里插入图片描述
  • 情况1
    在这里插入图片描述
  • 情况2
    在这里插入图片描述

IDEA 在debug中
MONITOR 对应 BLOCKED
WAIT 对应 WAITING
RUNNING 对应RUNNABLE
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.7 多把锁

在这里插入图片描述
2. 活跃性

  • 死锁
    在这里插入图片描述
    在这里插入图片描述
  • 哲学家问题
  • 活锁
    在这里插入图片描述

在这里插入图片描述

  • 饥饿问题
    在这里插入图片描述
    在这里插入图片描述

2.8 ReentrantLock

  1. 特点
    在这里插入图片描述
  • 可打断
  • 锁超时
    在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.9 同步模式之顺序控制

  1. 本章小结
    在这里插入图片描述

在这里插入图片描述

三 并发之 共享模型

3.1 序言

  1. JVM:
    • 原子性
    • 可见性
    • 有序性

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
3. 可见性 vs 原子性
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值