前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【每天一个小知识】锁的基本思想

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

作者头像
哆哆jarvis
发布2023-02-26 13:54:30
2930
发布2023-02-26 13:54:30
举报

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

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

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

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

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

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

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

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-02-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 哆哆jarvis 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档