Java中的各种锁

本文详细介绍了Java中的各种锁机制,包括乐观锁、悲观锁、共享锁、独占锁、公平锁、非公平锁、可重入锁、互斥锁、读写锁、分段锁、同步锁、死锁、自旋锁、锁粗化、锁消除以及重量级锁、偏向锁和轻量级锁。通过实例解释了它们的工作原理和应用场景。
摘要由CSDN通过智能技术生成

目录

乐观锁

悲观锁

共享锁

独占锁

公平锁

非公平锁

可重入锁

互斥锁

读写锁

分段锁

同步锁

 死锁

自旋锁

锁粗化

锁消除

重量级锁

偏向锁&轻量级锁

乐观锁

比较乐观的思想,认为在读的时候不会被修改,所以不会加锁。适用于读多写少的情况。

CAS:

        比较并替换,比较当前值(主内存中的值),与预期值(当前线程中的值,主内存中值的一份拷贝)是否一样,一样则更新,否则继续进行CAS操作。

悲观锁

悲观锁:比较悲观,认为什么情况下都不安全,所以一直都加锁。

实现:Lock、synchronized

共享锁

 共享锁:自己读取资源的同时,也允许别的线程一块读取。读锁。

实现:ReadLock,ReentrantReadWriteLock

独占锁

独占锁:自己占有的资源不允许别人再次获取。

实现:WriteLock,synchronized,ReentrantLock

公平锁

公平锁:多个线程同时访问一块数据,线程按照先来后到的顺序进行访问对应的资源。

实现:ReentrantLock(参数)
比如我们去领快递排队一样,先来后到。

非公平锁

非公平锁:多个线程同时访问一块数据,线程谁先抢到对应的资源谁先使用。

实现:ReentrantLock、synchronized
比如超时搞促销活动,谁先抢到是谁的。

可重入锁

可重入锁:获取过锁的线程,不释放锁之前,是否能够重复

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java有多种,可以根据应用场景的不同选择不同的。 1. synchronized:synchronized是Java最基本的。它是一种互斥,同一时间只能有一个线程持有该,其他线程必须等待该线程释放才能获得。synchronized可以应用于方法或代码块。 2. ReentrantLock:ReentrantLock是Java的另一种互斥,与synchronized相比,它的灵活性更高,可以指定公平或非公平的获取方式。在高并发环境下,ReentrantLock的性能可能比synchronized更好。但是,它需要手动释放,否则可能会导致死。 3. ReadWriteLock:ReadWriteLock是Java的一种读写,它允许多个线程同时读取共享资源,但只允许一个线程写入共享资源。在读多写少的场景下,使用ReadWriteLock可以提高程序的并发性能。 4. StampedLock:StampedLock是Java8新增的一种,它比ReadWriteLock更加灵活,支持乐观读取和写,可以大幅度提高程序的并发性能。但是,StampedLock的使用要求比较高,需要仔细考虑的使用场景。 5. CAS:CAS(Compare And Swap)是Java的一种无算法,它通过比较内存的值与期望值是否相等来判断是否发生了竞争。如果没有竞争,就将新值写入内存;如果有竞争,则重新尝试。CAS的性能非常高,但是它对程序员的要求也非常高,需要处理好竞争和冲突问题。 6. Semaphore:Semaphore是Java的一种信号量,它可以控制同时访问某个资源的线程数量。Semaphore可以应用于控制并发访问的线程数量、线程池的大小等场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值