【linux】自旋锁与读写锁

news/2024/4/24 23:23:37/文章来源:https://blog.csdn.net/qq_66314292/article/details/130373173

文章目录

  • 一、自旋锁
    • 1.1 挂起等待和自旋等待
    • 1.2 自旋锁的接口
      • 1.2.1 自旋锁的初始化与销毁
      • 1.2.2 自旋锁的加锁与解锁
  • 二、读者写者模型
    • 2.1 场景引入
    • 2.2 读写锁的接口
      • 2.2.1 读写锁的初始化与销毁
      • 2.2.2 读写锁的加锁与解锁
    • 2.3 伪代码原理
    • 2.4 读者优先与写者优先

一、自旋锁

1.1 挂起等待和自旋等待

先来看两种场景:
1️⃣ 当一个线程申请锁的时候发现申请不了就去干其他的事情了,这种状态叫做挂起等待。等着锁被释放后才能被唤醒。
2️⃣ 当一个线程申请锁的时候发现申请不了就不停的询问该锁是否被释放。我们把这种状况叫做自旋等待

而是什么决定了等待的方式?

取决于我们要等待的时长。也就是成功申请到了临界资源的线程要在临界区待多长时间。

那么如何定义时间的长短呢?

我们可以看使用场景,当有很多IO操作或者要等待某种软件条件……一般都是要挂起等待的,如果在临界区是非常简单的内存操作一般是自旋等待。

一般情况我们都会选择挂起等待,因为如果使用自旋等待出现了死锁的情况的话,所有的执行流疯狂的自旋,会迅速占满CPU资源。

而因为选择哪种等待方式是由程序员决定的,所以我们也可以把两种方式都用一下来测试效果看看谁好谁坏。

1.2 自旋锁的接口

我们前面介绍的锁pthread_mutex和信号量sem都属于挂起等待的范畴。

而自旋锁也有它自己的类型:

pthread_spinlock_t *lock

1.2.1 自旋锁的初始化与销毁

#include <pthread.h>int pthread_spin_destroy(pthread_spinlock_t *lock);
int pthread_spin_init(pthread_spinlock_t *lock, int pshared);

1.2.2 自旋锁的加锁与解锁

加锁:

#include <pthread.h>int pthread_spin_lock(pthread_spinlock_t *lock);
int pthread_spin_trylock(pthread_spinlock_t *lock);

解锁:

#include <pthread.h>int pthread_spin_unlock(pthread_spinlock_t *lock);

可以看到跟我们之前使用的互斥锁的接口大同小异。其实用起来跟互斥锁一摸一样,在用户眼里不管是挂起等待还是自旋等待都是等待

二、读者写者模型

2.1 场景引入

我们小时候班级都有画黑板报的经历,我们把画黑板报的人称为写者,看黑板报的人称为读者
我们来讨论它们之间的关系:
写者与写者:

写者和写者的关系是典型的互斥关系(不考虑画在不同的区域的情况),因为可能会发生覆盖情况。

读者与写者:

当写者没写完的时候读者就有可能会去读,这样读者也不知道自己读了个什么,所以它们之间也应该有互斥关系。
还有一种情况,写者已经写完了,都没有人来看过就擦掉了,更新了板报,那会有什么意义呢?所以读者和写者之间一定有同步关系。

读者和读者:

读者和读者之间没有关系,不存在互斥或者同步。因为大家都能看黑板报。

这跟之前我们讲过的【linux】基于阻塞队列的生产者消费者模型(条件变量)的区别就是消费者会拿走数据,读者不会。

那么读者写者问题适用于什么场景呢?

一旦发布出来,很长时间都不会做修改,大部分时间都是被读取的,就例如我们写的博客。

2.2 读写锁的接口

2.2.1 读写锁的初始化与销毁

#include <pthread.h>int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);
int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock,const pthread_rwlockattr_t *restrict attr);

2.2.2 读写锁的加锁与解锁

读者加锁:

#include <pthread.h>int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwlock);

写者加锁:

#include <pthread.h>int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);

读者和写者加锁是不同的接口,但是解锁是一个接口。
解锁:

#include <pthread.h>int pthread_rwlock_unlock(pthread_rwlock_t *rwlock);

2.3 伪代码原理

读者有把锁和计数器:

pthread_mutex_t rdlock;
int rdcnt = 0;

写者也有自己的一把锁:

pthread_mutex_t wrlock;

当读者读取数据的时候:

lock(&rdlock);
rdcnt++;
if(rdcnt == 1)
{// 不让写者进来lock(&wrlock);
}
unlock(&rdlock);// 读取数据……
lock(&rdlock);rdcnt--;
if(rdcnt == 0)
{// 现在可以让写者进入unlock(&wrlock);
}
unlock(&rdlock);

写者写入的过程就简单得多:

lock(&wrlock);
// 写入
unlock(&wrlock);

在任意的一个时刻,只允许一个写者写入,但是允许多个读者读取

2.4 读者优先与写者优先

当有多个读者的时候,就很可能让写者无法进入,造成写者的饥饿问题,而这是正常的,毕竟读者写者模型就是要大部分时间是读取状态,我们管这种状态叫做读者优先

那么写者优先呢?

比方说现在有十个读者,已经进去了五个,此时写者就能拦住后边没有进去的五个,等待进去的线程读完就可以写了。



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

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java BIO

1.Java BIO(Blocking IO:同步并阻塞式IO)编程 1.1.基本介绍 1>.Java BIO就是传统的java io编程,其相关的类和接口在"java.io"包下; 2>.BIO(Blocking I/O): 同步阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处…

centos配置nacos集群

nacos配置集群 1.官方文档地址 https://nacos.io/zh-cn/docs/cluster-mode-quick-start.html 2.环境准备 1.64 bit OS&#xff0c;支持 Linux/Unix/Mac/Windows。&#xff08;至少3台&#xff0c;或者通过修改端口在一台服务器 启动多个nacos进行测试&#xff09;。 2.64 bit …

Three.js+TypeScript+Webpack学习记录(三)

使用环境参考 Node.js v16.19.1 正文 独立功能文件 我们不可能一直在 index.ts 中写代码&#xff0c;分离文件&#xff1a; // init.ts import * as THREE from threeexport const initScene () > {const scene new THREE.Scene()scene.background new THREE.Color(wh…

ChatGPT能用来写小说吗-gpt可以续写小说吗

怎么用ChatGPT写网文 ChatGPT是一个语言生成模型&#xff0c;可以用于生成各种文本&#xff0c;包括网文。下面是一些写网文的建议。 确定你的主题和情节。在开始写作之前&#xff0c;你需要确保你有一个明确的主题和情节&#xff0c;这可以帮助你更好地组织你的故事&#xff0…

电脑硬盘分区合并怎么操作?分享2个方法!

案例&#xff1a;电脑硬盘怎么分区&#xff1f; 【我把我的电脑硬盘分成了多个区域&#xff0c;这样可以方便存储和管理数据。现在我需要调整分区&#xff0c;对分区进行合并&#xff0c;但我不知道该如何操作&#xff0c;有没有小伙伴知道&#xff1f;】 在使用电脑的过程中…

【python视图3】networkx图操作示例

一、说明 根据定义&#xff0c;图是节点&#xff08;顶点&#xff09;以及已识别的节点对&#xff08;称为边、链接等&#xff09;的集合。在 NetworkX 中&#xff0c;节点可以是任何可哈希对象&#xff0c;例如文本字符串、图像、XML 对象、另一个图形、自定义节点对象等。 如…

perf生成火焰图

文章目录 1&#xff0c;top发现webserver进程空转情况下CPU占用高达200%2&#xff0c;使用性能分析工具perf来进行分析2.1&#xff0c;抓取采集样本2.2&#xff0c;使用perf简单分析性能数据 3&#xff0c;火焰图3.1&#xff0c;生成火焰图3.2&#xff0c;将生成的.svg文件用浏…

Chapter 4 :Constraining I/O Delay(ug903)

4.1 About Constraining I/O Delay 要在设计中准确地建模外部时序上下文&#xff0c;必须为输入和输出端口提供时序信息。由于XilinxVivado集成设计环境&#xff08;IDE&#xff09;只能识别FPGA边界内的时序&#xff0c;因此必须使用以下命令来指定超出这些边界的延迟…

数据库系统工程师——第五章 网络基础知识

文章目录 &#x1f4c2; 第五章、网络基础知识 &#x1f4c1; 5.1 计算机网络概述 &#x1f4d6; 5.1.1 计算机网络的概念 &#x1f4d6; 5.1.2 计算机网络的分类 &#x1f4d6; 5.1.3 网络的拓扑结构 &#x1f4c1; 5.2 网络硬件基础 &#x1f4d6; 5.2.1 网络设备 &…

【k8s】ruoyi微服务迁移到k8s

书接上回【传统方式部署Ruoyi微服务】&#xff0c;此刻要迁移至k8s。 环境说明 31 master &#xff0c; 32 node1 &#xff0c; 33 node2迁移思路 交付思路: 其实和交付到Linux主机上是一样的&#xff0c;无外乎将这些微服务都做成了Docker镜像; 1、微服务数据层: MySQL、 R…

“井电双控”地下水远程计量设施-实现地下水资源合理利用

“井电双控”地下水远程计量设施&#xff08;MGTR-W4122C&#xff09;是针对取水计量控制系统开发智能终端产品。集预收费、流量监测、电量监测、余额提醒、欠费停机、无线传输、远程控制等多种功能于一体&#xff0c;并可根据项目需求选择实体IC卡和APP电子卡取水两种方式。其…

换肤实现及LayoutInflater原理

文章目录 背景实现换肤步骤解析插件 apk 的包信息获取插件 apk 的 Resources 对象替换资源 简单的插件化换肤实现和存在的问题换肤如何动态刷新&#xff1f;控件换肤刷新的性能考虑如何降低 xml 布局中 View 的替换成本LayoutInflater 原理LayoutInflater.Factory2 替换 View 小…

David Silver Reinforcement Learning -- Markov process

1 Introduction 这个章节介绍关键的理论概念。 马尔科夫过程的作用&#xff1a; 1&#xff09;马尔科夫过程描述强化学习环境的方法&#xff0c;环境是完全能观测的&#xff1b; 2&#xff09;几乎所有的RL问题可以转换成MDP的形式&#xff1b; 2 Markov Processes 2.1 Mark…

从源码全面解析LinkedBlockingQueue的来龙去脉

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱敲代码的小黄&#xff0c;独角兽企业的Java开发工程师&#xff0c;CSDN博客专家&#xff0c;阿里云专家博主&#x1f4d5;系列专栏&#xff1a;Java设计模式、数据结构和算法、Kafka从入门到成神、Kafka从成神到升仙…

mall-swarm微服务商城系统

mall-swarm是一套微服务商城系统&#xff0c;采用了 Spring Cloud 2021 & Alibaba、Spring Boot 2.7、Oauth2、MyBatis、Docker、Elasticsearch、Kubernetes等核心技术&#xff0c;同时提供了基于Vue的管理后台方便快速搭建系统。mall-swarm在电商业务的基础集成了注册中心…

【Excel统计分析插件】上海道宁为您提供统计分析、数据可视化和建模软件——Analyse-it

Analyse-it是Microsoft Excel中的 统计分析插件 它为Microsoft Excel带来了 易于使用的统计软件 Analyse-it在软件中 引入了一些新的创新统计分析 Analyse-it与 许多Excel加载项开发人员不同 使用完善的软件开发和QA实践 包括单元/集成/系统测试 敏捷开发、代码审查 …

HCIA-RS实验-ENSP搭建一个基础的IP网络

HCIA-RS是华为认证网络工程师&#xff08;Routing & Switching&#xff09;的缩写。通过考取HCIA-RS证书&#xff0c;可以证明自己有能力设计、实现和维护小型网络。而HCIA-RS实验则是考试的一部分&#xff0c;是考生必须要完成的实践环节。这将是第一篇文章&#xff0c;后…

【Android Framework (八) 】- Service

文章目录 知识回顾启动第一个流程initZygote的流程system_serverServiceManagerBinderLauncher的启动AMS 前言源码分析1.startService2.bindService 拓展知识1:Service的两种启动方式对Service生命周期有什么影响&#xff1f;2:Service的启动流程3:Service的onStartCommand返回…

紧密联结玩家 | 2023 Google 游戏开发者峰会

玩家的选择是对游戏莫大的认可&#xff0c;重视玩家反馈并和他们建立联系是您的游戏取得成功的关键。我们也在努力创造更多机会&#xff0c;让您的游戏从琳琅满目的列表中脱颖而出&#xff0c;帮助您吸引更多用户。 上篇内容我们介绍了帮助您优化游戏性能的几大功能更新&#x…

❀五一劳动节来啦❀

今年“五一”&#xff0c;4月29日至5月3日放假调休&#xff0c;共5天。 如果你在5月4日到5月6日请假3天&#xff0c;加上5月7日周日&#xff0c;就可以形成9天的假期。 一&#xff0c;五一劳动节的由来⭐ 国际劳动节又称“五一国际劳动节”“国际示威游行日”&#xff08;英语…