Tianyi's Blog Tianyi's Blog
首页
  • 计算机网络
  • 操作系统
  • 计算机科学
  • Nginx
  • Vue框架
  • 环境配置
  • Java
  • JVM
  • Spring框架
  • Redis
  • MySQL
  • RabbitMQ
  • Kafka
  • Mirror Sites
  • Dev Tools
  • Docker
  • Jenkins
  • Scripts
  • Windows
  • 科学上网
  • 旅行
  • 网站日记
  • 软件
  • 电子产品
  • 杂野
  • 分类
  • 友情链接
GitHub (opens new window)

Tianyi

一直向前,永不停止
首页
  • 计算机网络
  • 操作系统
  • 计算机科学
  • Nginx
  • Vue框架
  • 环境配置
  • Java
  • JVM
  • Spring框架
  • Redis
  • MySQL
  • RabbitMQ
  • Kafka
  • Mirror Sites
  • Dev Tools
  • Docker
  • Jenkins
  • Scripts
  • Windows
  • 科学上网
  • 旅行
  • 网站日记
  • 软件
  • 电子产品
  • 杂野
  • 分类
  • 友情链接
GitHub (opens new window)
  • Java

    • web基础
    • 策略模式
    • Java基础语法
    • JavaWeb-Base
    • Optional处理空指针,这几招你会了吗?
    • 并发编程的艺术
    • 并发编程工具
    • 一个简单的 web 服务器实例
    • 小笔记-线程池
    • 小笔记-JUC入门
  • Golang

  • JVM的奇妙世界

  • Spring

  • Spring增强封装

  • Redis

  • MySQL

  • RabbitMQ

  • Kafka

  • 分享

  • 后端
  • Java
tianyi
2021-09-26

小笔记-JUC入门

JUC:
是什么:工具类
怎么玩:
1.高内聚低耦合,线程操作资源类:实现买票
2.Lock接口(synchronized与Lock区别)
3.判断 干活 通知(防止虚假唤醒:while判断)
4.辅助类:CountDownLatch+ CyclicBarrier+ Semaphore

Thread.State:
6状态:new runnable blocking waiting timed_waiting terminated


synchronized与Lock的区别:
1.首先synchronized是java内置关键字,在jvm层面,Lock是个java类;
2.synchronized无法判断是否获取锁的状态,Lock可以判断是否获取到锁;
3.synchronized会自动释放锁(a 线程执行完同步代码会释放锁 ;b 线程执行过程中发生异常会释放锁),Lock需在finally中手工释放锁(unlock()方法释放锁),否则容易造成线程死锁;
4.用synchronized关键字的两个线程1和线程2,如果当前线程1获得锁,线程2线程等待。如果线程1阻塞,线程2则会一直等待下去,而Lock锁就不一定会等待下去,如果尝试获取不到锁,线程可以不用一直等待就结束了;
5.synchronized的锁可重入、不可中断、非公平,而Lock锁可重入、可判断、可公平(两者皆可)
6.Lock锁适合大量同步的代码的同步问题,synchronized锁适合代码少量的同步问题。


CAS:
是什么:乐观锁
能干什么:在线程安全的情况下对数据进行修改
怎么玩:
1.(1)读取i值;(2)加1;(3)将新值写回i
2.优点:锁的粒度更小,性能更高
3.缺点:ABA问题——添加版本信息AtomStampReference,使用CompareAndSet更加安全的CAS解决ABA问题。
4.CAS自旋会造成性能问题
5.只能对简单的类型进行操作


BlockingQueueDemo
是什么:阻塞队列
能干什么:将worker挂起
怎么玩:
1.常用:ArrayBlockingQueue、LinkedBlockingQueue
2.操作:offer,poll,peek


ForkJoinPool:
是什么:分治合并线程池
怎么玩:
1.ForkJoinTask(Future)、RecursiveTask(递归)、ForkJoinPool
2.一般FutureTask多用于耗时的计算,主线程可以在完成自己的任务后,再去获取结果。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
完善页面 (opens new window)
小笔记-线程池
Go Basics

← 小笔记-线程池 Go Basics→

最近更新
01
JDK
02-23
02
BadTasteCode && 优化
09-11
03
Gradle 实践操作指南及最佳实践
09-11
更多文章>
Theme by Vdoing | Copyright © 2021-2025 Tandy | 粤ICP备2023113440号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式