后端面试话术集锦第 十六 篇:java锁面试话术

这是后端面试集锦第十六篇博文——java锁面试话术❗❗❗

1. 介绍一下乐观锁和悲观锁


乐观锁的话就是比较乐观,每次去拿数据的时候,认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号机制或者CAS算法实现。

乐观锁在读操作比较多的场景比较适用,这样可以提高吞吐量,就像数据库提供的write_condition机制,其实都是乐观锁。

悲观锁的话就是每次去拿数据的时候,也认为别人会修改数据,这个时候就会加上锁,这就导致其他线程想拿数据的话,就会阻塞,直到这个线程修改完成才会释放锁,让其他线程获取数据。

在数据库里的行级锁、表级锁都是在操作之前就先锁住数据再操作数据 ,都属于悲观锁。

Java中的synchronizedReentrantLock等独占锁就是悲观锁思想的实现。

·Java·中各种锁其实都是悲观锁的实现,在操作数据的时候,数据都会被当前线程锁住。

2. 介绍一下公平锁和非公平锁

  1. 公平锁:

    • 指线程在等待获取同一个锁的时候,是严格按照申请锁的时间顺序来进行的。

    • 这就意味着在程序正常运行的时候,不会有线程执行不到的情况,但是也需要额外的机制来维护这种顺序,所以效率相对于非公平锁会差点。

  2. 非公平锁&

你可能感兴趣的:(面试专栏-前端,后端面试,java,后端,跳槽,职场和发展,职场发展,面试,线程锁)