前言 乐观锁和悲观锁问题,是出现频率比较高的面试题。本文将由浅入深,逐步介绍它们的基本概念、实现方式(含实列)、适用场景,以及可能遇到的问题面试官追问,希望能帮助你打动面试官。 一、基本概念 乐观锁和悲观锁是两种思想,用于解决并发场景下的数据竞争问题。 乐观锁:乐观锁在操作数据时非常乐观、认为别人不 ...
分类:
其他好文 时间:
2019-05-02 19:03:57
阅读次数:
136
一、问题引出 1. 假设当当网上用户下单买了本书,这时数据库中有条订单号为001的订单,其中有个status字段是’有效’,表示该订单是有效的; 2. 后台管理人员查询到这条001的订单,并且看到状态是有效的; 3. 用户发现下单的时候下错了,于是撤销订单,假设运行这样一条SQL: update o ...
分类:
数据库 时间:
2019-05-01 11:56:07
阅读次数:
152
转:https://www.cnblogs.com/kismetv/p/10787228.html 概念:乐观锁和悲观锁是两种思想,用于解决并发场景下的数据竞争问题。 乐观锁:乐观锁在操作数据时非常乐观,认为别人不会同时修改数据。因此乐观锁不会上锁,只是在执行更新的时候判断一下在此期间别人是否修改了 ...
分类:
其他好文 时间:
2019-04-29 09:40:37
阅读次数:
154
乐观锁: 乐观锁不是数据库自带的,需要我们编程自己去实现的,乐观锁是指操作数据库时(更新数据库),想法很乐观,认为这次的操作不会导致冲突,在操作数据时,并不进行任何的特殊处理(也就是不加锁),而在进行更新后,再去判断是否有冲突了。 通常实现是这样的:在表中的数据进行操作时(更新),先给数据表增加一个 ...
分类:
数据库 时间:
2018-12-24 02:46:28
阅读次数:
160
在写入数据库的时候需要有锁,比如同时写入数据库的时候会出现丢数据,那么就需要锁机制。 数据锁分为乐观锁和悲观锁,那么它们使用的场景如下: 1. 乐观锁适用于写少读多的情景,因为这种乐观锁相当于JAVA的CAS,所以多条数据同时过来的时候,不用等待,可以立即进行返回。 2. 悲观锁适用于写多读少的情景 ...
分类:
数据库 时间:
2018-12-23 20:51:54
阅读次数:
167
一乐观锁 总是认为不会产生并发问题,每次去取数据的时候总认为不会有其他线程对数据进行修改,因此不会上锁,但是在更新时会判断其他线程在这之前有没有对数据进行修改,一般会使用版本号机制或CAS操作实现。 version方式:一般是在数据表中加上一个数据版本号version字段,表示数据被修改的次数,当数 ...
分类:
其他好文 时间:
2018-12-20 23:19:04
阅读次数:
238
title: 乐观锁和悲观锁 date: 2018 07 25 20:32:31 tags: categories: 何谓悲观锁与乐观锁 乐观锁对应于生活中乐观的人总是想着事情往好的方向发展,悲观锁对应于生活中悲观的人总是想着事情往坏的方向发展。这两种人各有优缺点,不能不以场景而定说一种人好于另外一 ...
分类:
其他好文 时间:
2018-12-19 17:57:06
阅读次数:
157
何谓悲观锁与乐观锁乐观锁对应于生活中乐观的人总是想着事情往好的方向发展,悲观锁对应于生活中悲观的人总是想着事情往坏的方向发展。这两种人各有优缺点,不能不以场景而定说一种人好于另外一种人。 悲观锁 总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个 ...
分类:
其他好文 时间:
2018-12-02 01:20:57
阅读次数:
311
乐观锁和悲观锁 乐观锁和悲观锁是在数据库中引入的名词,但是在并发包锁里面也引入了类似的思想,所以这里还是有必要讲解一下。 悲观锁指对数据被外界修改持保守的态度,认为数据很容易就会被其他线程修改,所以在数据被处理前就先对数据加锁,并在整个数据处理过程中,使数据处于锁定状态,悲观锁的实现往往依靠数据库提 ...
分类:
编程语言 时间:
2018-11-11 16:56:41
阅读次数:
185
沉淀再出发:java中的CAS和ABA问题整理 一、前言 在多并发程序设计之中,我们不得不面对并发、互斥、竞争、死锁、资源抢占等等问题,归根到底就是读写的问题,有了读写才有了增删改查,才有了所有的一切,同样的也有了谁读谁写,这样的顺序和主次问题,于是就有了上锁,乐观锁和悲观锁,同步和异步,睡眠和换入 ...
分类:
编程语言 时间:
2018-10-28 14:56:22
阅读次数:
169