【每天一个小知识】锁的基本思想

简介: 锁的基本思想

在并发环境下,如何对资源进行保护,防止多个线程同时操作一个变量?

我们假定有两个线程来分别从银行卡和存折进行取款操作,当A线程执行完判断语句后,获得了当前账户中的余额数(1000元),因为余额大于取款金额,所以准备执行取钱操作(从账户中减去1000元),但此时它被线程B打断,然后,线程B根据余额(1000),从中取出1000元,然后,将账户里面的余额减去1000元,然后,返回执行线程A的动作,这个线程将从上次中断的地方开始执行:也就是说,它将不再判断账户中的余额,而是直接将上次中断之前获得的余额减去1000。此时,经过两次的取款操作,账户中的余额为100元,从账面上来看,银行支出了1000元,但实际上,银行支出了2000元

640.png

可以看到并发里的一个基本问题:我们希望原子式执行这串动作,但是由于单处理器上的中断或者多个线程在多处理器上并发执行,导致我们做不到,因此引入了锁,用于临界区资源。

锁其实是个变量,我们要声明某种类型的锁变量,如自旋锁、互斥锁,这个锁变量保存了锁在某个时刻的状态。它只有2种状态,要么是可用的,表示没有线程持有该锁;要么是被占用的,表示有一个线程持有锁,正处于临界区。

锁为程序员提供了最小程度的调度控制。进程是由操作系统调度器调度的,而锁则在一定程度上让程序员获得了一些控制权,通过给临界区加锁,可以保证临界区内只有一个线程活跃。

号主:一枚机械专业本科生,经历了转行,从外包逆袭到芯片原厂的Linux驱动开发工程师,深入操作系统的世界,贯彻终身学习、终身成长的理念。平时喜欢折腾,寒冬之下,抱团取暖,期待你来一起探讨技术、搞自媒体副业,程序员接单和投资理财。【对了,不定期送闲置开发板、书籍、键盘等等】。

如果你想了解我的转行经验,欢迎找我交流~gongzhong号【哆哆jarvis】

一起不断探索自我、走出迷茫、找到热爱,希望和你成为朋友,一起成长~


相关文章
|
资源调度 算法 JavaScript
Python基础专题 - 超级详细的 Random(随机)原理解析与编程实践
Python基础专题 - 超级详细的 Random(随机)原理解析与编程实践
1940 0
|
搜索推荐 Java 数据库
基于SpringBoot校园二手书交易管理系统
基于SpringBoot校园二手书交易管理系统
|
存储 Java 数据库连接
activiti工作流数据库表介绍
activiti工作流数据库表介绍
926 0
|
应用服务中间件 网络安全 nginx
|
8月前
|
存储 人工智能 搜索推荐
《3D端游世界角色技能连招的动画状态机轻量化实践》
本文围绕《剑影江湖》武侠端游主角多武器技能体系的动画状态机性能问题展开,针对传统设计中状态冗余、判断链长、资源复用率低等导致的帧率下降、连招断档等问题,提出分层状态机+模板化过渡、动态缓冲时长+优先级输入队列、共享状态机实例+角色数据注入、时间轴同步+预测触发四大优化方案。
359 4
|
12月前
|
前端开发 Java 微服务
2025 版 Java 学习路线图之技术方案与实操指南详解
这是一份详尽的Java学习路线图,涵盖从入门到精通的全流程。基础阶段包括环境搭建、语法基础与面向对象编程;进阶阶段深入数据结构、算法、多线程及JVM原理;框架阶段学习Spring、MyBatis等工具;数据库阶段掌握SQL与NoSQL技术;前端阶段了解HTML、CSS及JavaScript框架;分布式与微服务阶段探讨容器化、服务注册与发现;最后通过项目实战提升性能优化与代码规范能力。资源地址:[https://pan.quark.cn/s/14fcf913bae6](https://pan.quark.cn/s/14fcf913bae6)。
851 7
|
运维 Kubernetes Java
Java一分钟之Kubernetes(K8s):容器编排深入浅出
【6月更文挑战第6天】Kubernetes是容器编排的主流工具,简化分布式系统运维。本文介绍了K8s核心概念:节点、Pod、服务、部署和副本集。讨论了资源不足、依赖服务未就绪等常见问题及其解决策略,并提供创建Deployment的代码示例。学习K8s能提升部署效率和运维灵活性。
554 5
|
设计模式 Python
Python教程:一文了解Python工厂模式
工厂模式是一种创建型设计模式,它用于创建对象的实例,而无需在客户端代码中指定具体的类。通过引入工厂类,客户端代码只需要与工厂接口进行交互,而不需要了解实际创建的对象的细节。这样可以将对象的创建和使用分离开来,提高了代码的灵活性和可维护性。
345 2
|
消息中间件 人工智能 Kubernetes
AI 事件驱动场景 Serverless 实践
事件驱动是指事件在持续事务管理过程中,进行决策的一种策略。可以通过调动可用资源执行相关任务,从而解决不断出现的问题。通俗地说是当用户触发使用行为时对用户行为的响应。在 Serverless 场景下,事件驱动完美符合其设计初衷之一:按需付费。
AI 事件驱动场景 Serverless 实践
|
网络协议 芯片
电源常用通讯电路
这篇文章探讨了数字电源中的通讯电路,主要包括常用的RS485、RS232、CAN、TCP/IP和I2C等通讯方式。通讯方式分为串行和并行,串行通讯因成本低、易于扩展而更常见,又细分为单工、半双工和全双工以及同步和异步通讯。文中还介绍了RS232和RS485的电平转换电路,以及CAN总线的数据帧结构和隔离与非隔离电路。此外,提到了TCP/IP协议的层次结构及其在数字电源中的应用。
456 4