乐观锁和悲观锁(MySQL和Java)

news2024/9/20 22:47:29

乐观锁和悲观锁(MySQL和Java)

在并发编程中,为了确保数据的一致性和完整性,我们通常需要使用锁机制来控制对共享资源的访问。锁主要分为两种:乐观锁和悲观锁。本文将详细介绍这两种锁的概念、工作原理以及它们的优缺点。

悲观锁

悲观锁(Pessimistic Lock)是一种假定会发生并发冲突的锁机制,因此在操作数据之前,先将数据锁定,以防止其他线程修改数据。这种锁机制通常用于写操作较多的场景,因为它能确保数据的一致性和完整性。

工作原理

当一个线程想要操作某条数据时,它会首先尝试获取该数据的锁。如果获取成功,其他线程将无法对这条数据进行操作,直到该线程释放锁。

优缺点

  • 优点
    • 能够确保数据的强一致性。
    • 简单易用,适用于多写操作的场景。
  • 缺点
    • 可能导致大量的锁竞争,影响性能。
    • 容易引起死锁。

示例

在数据库中,悲观锁通常通过“SELECT … FOR UPDATE”语句来实现。例如:

SELECT * FROM orders WHERE id = 1 FOR UPDATE;

这条语句会在读取数据的同时锁定该行数据,直到事务提交或回滚。

乐观锁

乐观锁(Optimistic Lock)是一种假定不会发生并发冲突的锁机制,它在操作数据时不加锁,而是在提交更新时检查是否有其他线程修改了数据。如果发生冲突,则回滚并重试操作。这种锁机制适用于读操作较多的场景。

工作原理

乐观锁通常通过版本号或时间戳来实现。在更新数据时,检查当前版本号或时间戳是否与读取时一致,如果一致则更新,否则说明数据已被其他线程修改,回滚操作。

优缺点

  • 优点
    • 没有锁竞争,性能较高。
    • 适用于多读操作的场景。
  • 缺点
    • 无法确保数据的强一致性。
    • 需要处理重试逻辑,较为复杂。

示例

在数据库中,乐观锁通常通过版本号来实现。例如:

  1. 查询数据及版本号:
SELECT id, name, version FROM users WHERE id = 1;
  1. 更新数据时,检查版本号:
UPDATE users SET name = 'newName', version = version + 1 WHERE id = 1 AND version = 1;

如果版本号匹配,则更新成功;否则更新失败,需要重试。

Java中的乐观锁和悲观锁

悲观锁

在Java中,悲观锁通常通过synchronized关键字或ReentrantLock类来实现。synchronized关键字可以用来修饰方法或代码块,而ReentrantLock类提供了更灵活的锁控制。

// 使用synchronized关键字
public synchronized void method() {
    // 临界区代码
}

// 使用ReentrantLock
import java.util.concurrent.locks.ReentrantLock;

private final ReentrantLock lock = new ReentrantLock();

public void method() {
    lock.lock();
    try {
        // 临界区代码
    } finally {
        lock.unlock();
    }
}

乐观锁

在Java中,乐观锁通常通过java.util.concurrent.atomic包中的类来实现,例如AtomicIntegerAtomicLongAtomicReference等。这些类使用CAS(Compare And Swap)操作来实现无锁并发控制。

import java.util.concurrent.atomic.AtomicInteger;

private final AtomicInteger version = new AtomicInteger(0);

public void update() {
    int currentVersion = version.get();
    // 业务逻辑
    version.compareAndSet(currentVersion, currentVersion + 1);
}

MySQL中的乐观锁和悲观锁

在MySQL中,乐观锁和悲观锁主要通过事务控制和特定的SQL语句来实现。

悲观锁

在MySQL中,可以通过SELECT ... FOR UPDATE语句来实现悲观锁。例如:

START TRANSACTION;
SELECT * FROM orders WHERE id = 1 FOR UPDATE;
-- 执行需要锁定的操作
COMMIT;

乐观锁

乐观锁通常通过版本号或时间戳字段来实现。例如,在更新数据时,可以检查版本号是否一致:

  1. 查询数据及版本号:
SELECT id, name, version FROM users WHERE id = 1;
  1. 更新数据时,检查版本号:
UPDATE users SET name = 'newName', version = version + 1 WHERE id = 1 AND version = 1;

如果版本号匹配,则更新成功;否则更新失败,需要重试。

参考链接

  • MySQL 悲观锁:https://dev.mysql.com/doc/refman/8.0/en/innodb-locking.html
  • MySQL 乐观锁:https://dev.mysql.com/doc/refman/8.0/en/innodb-transaction-isolation-levels.html
  • Java并发:https://docs.oracle.com/javase/tutorial/essential/concurrency/

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1872652.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

字节码编程ASM之插桩方法执行耗时

写在前面 源码 。 本文看下如何对已有类进行插装。以最经典的方法执行耗时作为例子。 1:编码 假定有如下的代码: public class MyMethod {public String queryUserInfo(String uid) {System.out.println("xxxx");System.out.println("…

visual studio2022配置和使用protobuf

上图证明,我真的测了好多遍,测了好多版本的protobuf,花了很多时间。不过好在最后在vs2022上测通了。 下载protobuf 这里是protobuf下载的地址。 Releases protocolbuffers/protobuf GitHub 个人使用的3.21.9这个版本才跑通的。 1、首先…

【递归、搜索与回溯】floodfill算法二

floodfill算法二 1.被围绕的区域2.太平洋大西洋水流问题3.扫雷游戏4.衣橱整理 点赞👍👍收藏🌟🌟关注💖💖 你的支持是对我最大的鼓励,我们一起努力吧!😃😃 1.被围绕的区域…

【OpenSSH】关于操作系统中的自带的SSH你知道怎么用吗

希望文章能给到你启发和灵感~ 如果觉得文章对你有帮助的话,点赞 关注 收藏 支持一下博主吧~ 阅读指南 开篇说明一、基础环境说明1.1 硬件环境1.2 软件环境 二、如何开启SSH服务2.1 什么是OpenSSH2.2 对于Windows 10, Windows 11系统2.2.1 如…

bug记录-XFTP传输中文文件夹乱码

bug记录-XFTP传输中文文件夹乱码 今日想往服务器中同步一些脚本,脚本文件夹是中文命名的,用XFTP导入后发现文件夹名称是乱码的 但是在XFTP上显示是正常的 这是因为window默认是GBK编码 linux是UTF-8编码 所以我们只需要把XFTP会话的编码改为UTF-8就可以了 首先点击文件-当前…

【Android面试八股文】Framework面试:Handler怎么进行线程通信的?原理是什么?

文章目录 Handler整体思想Handler工作流程Handler工作流程图总结Handler整体思想 在多线程的应用场景中,将工作线程中需更新 UI 的操作信息 传递到 UI 主线程,从而实现 工作线程对 UI 的更新处理,最终实现异步消息的处理。 Handler工作流程 Handler 机制的工作流程主要包括…

VUE中,table border属性的不同使用方式

在vue中&#xff0c;使用table&#xff0c;在给table设置边框属性时&#xff0c;按照以往的习惯&#xff1a; <table border"1px solid"><table> 这种写法&#xff0c;产生的效果如下&#xff1a;下边、右边的边框明显和上边、左边不同。border属性设置…

【多维动态规划】Leetcode 97. 交错字符串【中等】

交错字符串 给定三个字符串 s1、s2、s3&#xff0c;请你帮忙验证 s3 是否是由 s1 和 s2 交错 组成的。 两个字符串 s 和 t 交错 的定义与过程如下&#xff0c;其中每个字符串都会被分割成若干 非空 子字符串 子字符串 是字符串中连续的 非空 字符序列。 s s1 s2 … snt…

2024年5月90篇代码大模型论文最全整理

引言&#xff1a; 本文整理 2024 年 5 月发布的 90 篇代码大模型相关论文&#xff0c;其中包括 17 篇发表在今年 ICLR 的论文。根据论文内容&#xff0c;我们将这些论文整理为了基座模型、代码微调、测试基准、代码 Agent、低资源语言处理、AI 代码安全与分析、人机交互、软件…

Lean4Game 开发教程 | 数学形式化

引言 Lean 是一门用于形式化证明的编程语言&#xff0c;它允许严格证明数学定理和验证软件代码的正确性。 本篇介绍 Lean 游戏的编写和发布方式。这类游戏不仅利于对 Lean 本身的学习&#xff0c;对学科知识的理解&#xff0c;还能推动数学圈内人对 Lean 的接触学习。 Lean4…

你不知道的物联网产品有那么多

目录 1. 智能农业设备 ​编辑1.1 土壤感应器 1.2 自动喷灌系统 2. 智能医疗设备 ​编辑2.1 可穿戴健康监测设备 2.2 智能药盒 3. 智能城市基础设施 ​编辑3.1 智能垃圾桶 3.2 智能路灯 4. 智能物流与供应链 ​编辑4.1 货物跟踪设备 4.2 智能仓储系统 5. 智能网关 …

linux server下人脸检测与识别服务程序的系统架构设计

一、绪论 1.1 定义 1.2 研究背景及意义 1.3 相关技术综述 二、人脸检测与识别技术概述 2.1 人脸检测原理与算法 2.2 人脸识别技术及方法 2.3 人脸识别过程简介 三、人脸检测与识别服务程序的系统架构 3.1 系统架构设计 3.2 技术实现流程 四、后续设计及经验瞎谈 4.…

【Mac】Listen 1 for Mac(最强的音乐搜索工具)软件介绍

软件介绍 Listen 1 for Mac 是一款非常方便的音乐播放软件&#xff0c;主要功能是集成多个音乐平台&#xff0c;让用户可以方便地搜索、播放和管理音乐。它是一个用 Python 语言开发的免费开源综合音乐搜索工具项目&#xff0c;最大的亮点在于可以搜索和播放来自网易云音乐&am…

全国公共汽车、出租车拥有情况及客运量、货运量数据

基本信息. 数据名称: 全国公共汽车、出租车拥有情况及客运量、货运量数据 数据格式: Shp、Excel 数据时间: 2020-2022年 数据几何类型: 面 数据坐标系: WGS84 数据来源&#xff1a;中国城市统计年鉴 数据可视化. 2022年全年公共汽车客运总量数据示意图 2022年公路客…

Apifox 更新|定时任务、内网自部署服务器运行接口定时导入、数据库 SSH 隧道连接

Apifox 新版本上线啦&#xff01; 看看本次版本更新主要涵盖的重点内容&#xff0c;有没有你所关注的功能特性&#xff1a; 自动化测试支持设置「定时任务」支持内网自部署服务器运行「定时导入」数据库均支持通过 SSH 隧道连接自动化测试数据库操作优化 1、自动化测试支持设…

计算机语言vs指令vs中央处理器cpu

计算机中如何表示数据 在计算机中&#xff0c;所有数据和指令都是用二进制表示的&#xff0c;即0和1。这些0和1实际上是电压信号的高低电平&#xff0c;0通常表示低电平&#xff08;如0伏特&#xff09;&#xff0c;1表示高电平&#xff08;如5伏特&#xff09;。 指令系统&a…

基本的 Spring Boot 配置步骤和常见的配置项【创建,配置,日志,数据库,安全,MVC】

基本的 Spring Boot 配置步骤和常见的配置项【创建&#xff0c;配置&#xff0c;日志&#xff0c;数据库&#xff0c;安全&#xff0c;MVC】 学习总结 1、掌握 JAVA入门到进阶知识(持续写作中……&#xff09; 2、学会Oracle数据库入门到入土用法(创作中……&#xff09; 3、…

UE5基本操作(二)

文章目录 前言相机的移动速度修改默认地图使用初学者内容包文件夹结构 总结 前言 在我们的上一篇文章中&#xff0c;我们已经介绍了一些Unreal Engine 5&#xff08;UE5&#xff09;的基本操作。UE5是一款强大的游戏开发引擎&#xff0c;它提供了许多工具和功能&#xff0c;使…

Elasticsearch 聚合查询

Hi~&#xff01;这里是奋斗的小羊&#xff0c;很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~~ &#x1f4a5;&#x1f4a5;个人主页&#xff1a;奋斗的小羊 &#x1f4a5;&#x1f4a5;所属专栏&#xff1a;C语言 &#x1f680;本系列文章为个人学习…

SpringMVC处理器映射器HandlerMapping详解

目录 一、前言 二、initHandlerMappings 三、处理器映射器架构 策略接口 请求链 模版类 四、RequestMappingHandlerMapping的初始化 HandlerMethod映射器模版类的初始化 AbstractHandlerMethodMapping.MappingRegistry&#xff1a;内部类注册中心 五、Reques…