×

synchronized底层

synchronized底层(SynchronizedList和Vector的区别)

admin admin 发表于2024-09-24 07:16:31 浏览1 评论0

抢沙发发表评论

其实synchronized底层的问题并不复杂,但是又很多的朋友都不太了解SynchronizedList和Vector的区别,因此呢,今天小编就来为大家分享synchronized底层的一些知识,希望可以帮助到大家,下面我们一起来看看这个问题的分析吧!

本文目录

SynchronizedList和Vector的区别

区别很大:SynchronizedList可以打包List麾下所有小弟:去掉两个抽象List与Vector还有7个,且这7个内部数据结构,还有所不同!说最简单的LinkedList底层是链表,打包后他变安全了,它与Vector完全不一样的概念!ArrayList虽底层与Vector一样都是数组数据结构,但还是不一样,最明显自动扩容的时候,就不一样!打包变安全了也不一样!

谈谈synchronized与ReentrantLock的区别

【死记硬背】

synchronized是JVM层面的锁,是Java关键字,通过monitor对象来完成(monitorenter与monitorexit),对象只有在同步块或同步方法中才能调用wait/notify方法。

ReentrantLock是从jdk1.5以来(java.util.concurrent.locks.Lock)提供的API层面的锁。

1 都是用来协调多线程对共享对象、变量的访问;

2 都是可重入锁,同一线程可以多次获得同一个锁;

3 都保证了可见性和互斥性;

1 ReentrantLock显示的获得、释放锁,synchronized隐式获得释放锁;

2 ReentrantLock可响应中断、可轮回,synchronized是不可以响应中断的,为处理锁的不可用性提供了更高的灵活性;

3 ReentrantLock是API级别的,synchronized是JVM级别的;

4 ReentrantLock可以实现公平锁,而synchronized不行;

5 ReentrantLock通过Condition可以绑定多个条件;

6 底层实现不一样,synchronized是同步阻塞,使用的是悲观并发策略,Lock是同步非阻塞,采用的是乐观并发策略;

7 Lock 是一个接口,而 synchronized 是 Java 中的关键字,synchronized 是内置的语言

实现。

8 synchronized 在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用 Lock 时需要在 finally 块中释放锁。

9 Lock可以让等待锁的线程响应中断,而 synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断;

10 通过Lock可以知道有没有成功获取锁,而synchronized却无法办到;

11 Lock 可以提高多个线程进行读操作的效率,既就是实现读写锁等;

【答案解析】

synchronized的锁使用案例:

ReentrantLock的锁使用案例:

【温馨提示】

OK,关于synchronized底层和SynchronizedList和Vector的区别的内容到此结束了,希望对大家有所帮助。