JDK1.8 锁的实现与原理(一) 自己实现一个锁

本文介绍了Java中的锁机制,包括关键字和Lock接口的区别,并通过示例展示了如何实现一个简单的并发控制。文章讨论了Atomic类的原子性操作以及基于CAS的无锁机制,还探讨了ReentrantLock的可重入特性,最后分析了锁的公平性和非公平性概念,以及读写锁的优化策略。
摘要由CSDN通过智能技术生成

Java中的锁机制

在学习Java的并发编程中, 锁机制是一个重点和难点, 在Java中并发常用到的锁相关的主要是synchronized关键字和java.util.concurrent.locks类, 两者的区别包括

  • synchronized是关键字, 依赖JVM实现锁机制, Lock是JDK中的一个接口, 其实现最典型的是ReentrantLock
  • synchronized的实现是编译期加入了管程的机制, ReentrantLock的实现是依赖底层的AbstractQueuedSynchronizer(AQS), 而AQS又使用到了Java中的CAS机制.
  • synchronized不需要手动释放, 在临界区的代码出现异常时, 也能够正确的进行自动解锁. Lock的实现类需要手动上锁和解锁, 为了保证代码出现异常时能够释放锁, 需要将代码段包在try-finally语句中
  • Lock实现类比synchonized更加灵活, 支持tryLock方法能够设置超时时间, 也可以控制被阻塞的线程是否能够相应中断, synchonized不行
  • Lock的实现类中读写锁可以提高读操作效率, 实现类也能够知道是否获得了锁
  • 在竞争不激烈时, 两者相差不大, 竞争激烈的情况下, Lock性能远优于synchonized
  • synchronized是可重入锁
  • synchronized不可中断, Lock可中断

说了怎么多, 不如动手写点代码, 从代码中了解并发编程中应该如何用锁, 以及一个锁大致是怎么实现.

一个并发操作的Demo

import java.util.LinkedList;
import java.util.List;

public class TestConcurrent {
   
    public static void main(String[] args) throws InterruptedException {
   
        Share share = new Share();
        List<Thread> tList = new LinkedList<>();
        for (int i = 0; i < 5; i++) {
   
            Thread t = new Thread(
              ()-> {
   
                  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值