多线程锁(synchronized 锁的执行顺序、公平锁和非公平锁)

目录

synchronized 锁的执行顺序:

公平锁和非公平锁


1、synchronized 锁的执行顺序:

synchronized同步锁对象级别,一个对象一把锁

static synchronized静态同步锁类级别,一个类一把锁

  1. 一个线程访问的都是同步锁时,(一个线程即一个对象,所以只有一把对象锁)是按顺序执行的
  2. 一个线程访问的都是静态同步锁(一个线程即一个类,所以只有一把类锁)是按顺序执行的
  3. 一个线程访问有静态同步锁也有同步锁时,两把锁,之间互不干扰。
  4. 多线程访问的都是同步锁时,多线程 多对象 多把对象锁,之间互不干扰
  5. 多线程访问的都是静态同步锁时,多线程属于同个类,只有一把类锁,所以按顺序执行。
  6. 多线程访问有静态同步锁也有同步锁时,同步锁间互不干扰,静态同步锁按顺序执行

 总结:

一个线程就一个对象,一个类;只能有一把同步锁,一把静态同步锁

多线程即多个对象,同个类;可以有多把同步锁,但只能有一把静态同步锁。

2、公平锁和非公平锁


公平锁:效率相对低 ,但是cpu 的利用高了
非公平锁:效率高,但是线程容易饿死(所有的工作,有一个线程完成)
用法: 在创建可重入锁时,想构造器中传入true

private final ReentrantLock lock = new ReentrantLock(true);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值