读者写者模型自旋锁(了解)

news2025/1/11 18:43:27

文章目录

      • 读者写者模型:
        • 1. 基本理论
          • 消费者生产者模型的321原则
        • 2. 操作
        • 3.理解
        • 4. 优先级
        • 挂起等待特性的锁 VS 自旋锁
          • 线程访问临界资源花费的时间问题:
          • 线程如何得知会在临界资源中等待的时间呢?
          • 自旋锁的使用

读者写者模型:

1. 基本理论

  1. 对数据大部分的操作是读取,少量的操作是写入
  2. 判断依据是进行数据读取或者消费的一端是否会将数据取走,如果不取走就可以考虑读者写者模型
    • 黑板报的例子
      • 读者和写者:互斥关系,同步关系。写完看,看完就写是同步。写完之前读到的内容肯定不全或者错误,所以是互斥。
      • 写者和写者:互斥关系,存在内容的覆盖
      • 读者和读者:没有关系,因为读者不会取走资源而消费者之间会存在竞争关系
    • 各种关系之间依靠加锁的方式维护
消费者生产者模型的321原则

3:三种关系

读者和读者,读者和写者,写者和写者

2:两种角色

1:一个交易场所

提供一段缓冲区

2. 操作

1664767289989

3.理解

1664767387550

读者reader++的过程中写者可以竞争到锁进来,如果有读者就挂起wait(),此时锁是释放的,交给读者来–,等到reader==0,wait属性重新获取锁从而实现下面的操作。在写者wait()之后获取锁开始进行修改时,任何的写者或者读者都无法进入,就维护了互斥关系。

4. 优先级

读者优先:读者和写者同时到来的时候,我们让读者先进入访问。

写者优先:读者和写者同时到来的时候,比当前写者晚来的所有读者都不要进入临界区访问了,邓林杰去中没有读者了让写者进去。

默认读者优先,本来读者多写者少,所以会存在写饥饿问题的。

挂起等待特性的锁 VS 自旋锁

线程挂起等待,然后再用条件变量唤醒

1664769086542

线程访问临界资源花费的时间问题:

线程的挂起是需要成本的,线程PCB的等待队列和状态的调整。

  • 如果花费的时间很长,就适合挂起等待锁。
  • 如果花费时间很短,没必要挂起等待没有竞争到锁的线程,就适合自旋锁,不断通过循环检测锁的状态。
线程如何得知会在临界资源中等待的时间呢?

线程不知道,程序员知道。

自旋锁的使用

1664769542434

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

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

相关文章

Python实现FA萤火虫优化算法优化支持向量机回归模型(SVR算法)项目实战

说明:这是一个机器学习实战项目(附带数据代码文档视频讲解),如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 萤火虫算法(Fire-fly algorithm,FA)由剑桥大学Yang于2009年提出 , 作…

ModBus协议学习

之前没接触过,记录一下抄的东西。 Modbus 一个工业上常用的通讯协议、一种通讯约定。Modbus协议包括RTU、ASCII、TCP。其中MODBUS-RTU最常用,比较简单,比较容易实现。 先来简单分析一条MODBUS-RTU报文,例如:01 06 0…

Spring Boot 构建多租户SaaS平台核心技术指南

1. 概述 笔者从2014年开始接触SaaS(Software as a Service),即多租户(或多承租)软件应用平台;并一直从事相关领域的架构设计及研发工作。机缘巧合,在笔者本科毕业设计时完成了一个基于SaaS的高…

绘制一张透明背景的单色位图

在上一篇文章中,我留下了一个谜题:如何使用透明背景绘制一张单色位图。今天我们来揭晓谜底。 丑话说前头,我不是一名 GDI 方面的专家,所以,除了下面讲述的两种方法之外,可能还有我所不知道的更好的解决方案…

九、Map接口和常用方法

文章目录框架特点常用方法六大遍历方式练习框架 数据是K-V类型的我们之前学的几个Set底层也是封装了Map,但是Value部分用默认值,我们只使用Key部分 特点 注意:这里讲的是JDK8的Map接口特点 Map用于保存具有映射关系的数据:Key-…

c++类和对象

二、c类和对象 1.什么是类 c当中类是一个数据类型,封装了数据以及操作。个人理解:c类就是对事物的的抽象,c万物即可为类,和c语言的结构体一样,是一系列事物的共同属性和行为 2.什么是对象 对象就是类的具体化(实例化)…

git创建远程分支并关联本地分支

场景一: 本地、远程都没有分支 "v1.0.0" 1. 先查看确认一下,命令: git branch -a 2. 创建本地分支,命令: git checkout -b v1.0.0 3. 创建远程分支,并且本地分支关联远程分支,命令…

上海亚商投顾:沪指缩量跌0.44% 医药股全线反弹

上海亚商投顾前言:无惧大盘大跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。 市场情绪大小指数今日走势分化,沪指全天弱势震荡,创业板指盘中涨超1%,午后涨幅有所回落。…

2022-12-29 驱动-IO多路复用

IO多路复用的原理: 1>select和poll原理:将文件描述符添加到集合中,监测是否有准备就绪的文件描述符,将未准备就绪的文件描述符剔除集合,准备就绪的文件描述符实现相关操作 2>对于epoll函数原理:创建…

超融合一体流式引擎,打造分布式数据库新纪元

12月28日,“数智驱动 全栈赋能”亚信科技2022年度系列产品发布会“数据库专场”线上成功举办,亚信科技重磅发布“超融合一体流式引擎”的AntDB V7.2数据库,并分享了在通信、交通等行业的应用实践。 百行千业数智化转型风起云涌,企…

布局云计算的下一个主场,紫光云引领行业云三大趋势

早在2018年,中国信通院发布2018云计算白皮书并指出:行业云时代全面开启。4年后的2022年底,Gartner将行业云平台列入2023年十大战略技术趋势,Gartner预测到2027年将有超过50%的企业使用行业云平台加速其业务项目。可以说&#xff0…

数据结构----树

树的概念 1.树的定义:树是n(n>0)个结点的有限集合 当n0时,称为”空树“ 当n>0时,有且仅有一个称为”根“的特定结点,该结点没有前驱,但是却有一个或者多个后继结点。 除了根节点以外的n-1个结点可划分为多个有…

项目管理范围(下)

创建WBS 什么是WBS? WBS(Work Breakdown Structure) --- 工作分解结构 创建WBS是将项目的可交付成果和项目工作分解成较小的,更易于管理的组件的过程。 它包含哪些内容? 举例: 里程碑的例子:比如需求评审&#xff…

计算机SCI论文润色,更容易被录用吗? - 易智编译EaseEditing

SCI论文润色后投稿,相较于没有润色投稿,确实概率要大一些。 特别有些英语水平较差的作者,投稿的论文,没有润色之前,可能审稿人会不理解,或读不通。 润色后,可能帮助审稿人理解论文。 目前不少…

告别动态规划

一、动态规划的三大步骤 动态规划,无非就是利用历史记录,来避免我们的重复计算。而这些历史记录,我们得需要一些变量来保存,一般是用一维数组或者二维数组来保存。下面我们先来讲下做动态规划题很重要的三个步骤 第一步骤&#…

九、树结构基础

1、为什么需要树这种数据结构? 数组存储方式的分析 优点:通过下标方式访问元素,速度快。对于有序数组,还可使用二分查找提高检索速度。 缺点:如果要检索具体某个值,或者插入值(按一定顺序)会整体移动&…

简单BGP实验

(我这里AS1 BGP为100 AS2BGP为200 AS3 BGP为300) 这里已经配置好ip环回(这里tcp使用的是rip也已经提前配置好) 首先先配置AS2中的ibgp [r2]bgp 200 [r2-bgp]router-id 2.2.2.2 [r2-bgp]peer 4.4.4.4 as-number 100 [r2-bgp]…

白话初识UDP协议

UDP是什么 UDP是一个传输层的数据包装协议,特点有: 无连接(不需要两端连通就可以发送消息给接收端)不可靠传输(无法知道数据是否送达)面向数据报(以数据报为数据传输单位)全双工&…

vue项目cli2 升级 cli3

vue-cli2 升级 vue-cli3 由于vue-cli2 版本太低,升级到vue-cli3 采用的方法是新建cli3项目,对比差异,在cli2项目单独升级 检查环境 node环境检查版本是否在8.11版本以上 npm uninstall vue-cli -g 卸载旧版本的vue-cli npm install -g vue/…

广州蓝景分享—VSCode 前端开发必备插件推荐

Hello~~各位小伙伴好,今天广州蓝景整理一波前端开发必备插件,绝对可以提高你的生产力,希望这篇文章对大家有所帮助。 开发综合推荐 别名路径跳转 插件名:别名路径跳转 使用说明: 别名路径跳转插件,支持任何项目&…