<mutex>注释 12:重新思考与猜测、补充锁的睡眠与唤醒机制,结合 linux0.11 操作系统代码的辅助(下)

(60)继续分析,为什么 timed_mutex 可以拥有准时的等待时间

在这里插入图片描述

++逐步测试

在这里插入图片描述

++ 以及:

在这里插入图片描述

++以及:

在这里插入图片描述

++ 以及:

在这里插入图片描述

++ 上面的例子里之所以这么编写。无论 timed_mutex 里的定时等待函数,还是 条件变量 condition_variable 里的限时 wait_xx (…) 函数。最终都是调用上面的函数完成定时等待。所以手工为其凑齐了参数。直接调用了这个函数

在这里插入图片描述

(61) 列出简化版的 mutex 与 condition_variable 的源代码

在这里插入图片描述

++ 以及:

在这里插入图片描述

++ 根据上面的大量的测试,结合 linux 0.11 上的进程睡眠与唤醒的规律,推测一下上图中这些不同底层函数的功能。锁 mutex 的 加锁解锁,应该属于 不可中断睡眠状态,task_uninterruptable 。这类睡眠由 mutex . unlock () 来唤醒等待锁的线程。 条件变量是为了线程同步,避免线程的无意义的无序竞争锁,比如同一文件的读写线程之间的竞争,此情形就可以由 条件变量来规范线程的睡眠与唤醒。 调用了 condition_variable . wait ()的线程也会进入睡眠状态,但不是在锁上睡眠,而是在条件变量上睡眠,只可以由对应的 condition_variable . notify ()等函数来唤醒线程,然后这些被唤醒的线程再去竞争锁。所以在条件变量上睡眠的线程也属于在不可中断睡眠状态 task_uninterruptable 。因为 锁有 80 字节的内存,条件变量有 72 字节的内存,所以锁与条件变量都可以记录其上的睡眠线程的 id 的,或者是 线程控制块的地址 TCB ,以便于将来唤醒这些线程。 条件变量上的定时睡眠,应该属于 可中断睡眠状态 task_interruptable , 因为该线程要响应定时信号 SIGALRM ,以便在定时到时由操作系统唤醒,改为可运行状态 task_running 。但定时睡眠后,(包括 条件变量上的无限睡眠状态 condition_variable . wait ()),从条件变量上醒来后的线程,都要去竞争锁 mutex ,得不到锁的线程,还会再次进入睡眠状态,改为在 锁 mutex 上睡眠。下一次就不是条件变量来唤醒了,而是由 锁 mutex . unlock() 来唤醒。而且也对应了另一句话,在条件变量上睡眠的线程在调用 wait()前必须先持有锁。由 条件变量释放锁后把线程放在条件变量上睡眠,条件变量上的睡眠线程,醒来后的第一件事就是参与锁的竞争。条件变量上的限时睡眠,也可以被提前唤醒,但若断言条件不满足,还会继续睡眠,直到把指定的时间用完。

(62)至此,基本理清了定时锁 timed_mutex 为什么具有精确的醒来功能了,不会超时睡眠。因为 timed_mutex 中的 锁
timed_mutex . _My_mutex 是一直闲置的,不经常被加锁,所以定时睡眠的线程醒来后一定可以拿到这个锁。但 timed_mutex . _My_locked 这个整型数据的是否为 0 的语义,才表示临界资源是否空闲。锁 timed_mutex . _My_mutex 是为了在写 timed_mutex . _My_locked 时保护一下这个整形数据,然后就释放锁了。有点类似于双重锁定的功能与感觉。

类似的结构体设计,还有线程间共享数据,共享函数返回值的结构 _Associated_state《T》

在这里插入图片描述

++ 继续:

在这里插入图片描述

++ 也给出上面图的代码版本:

template <class _Ty>
struct _State_manager // class future : public _State_manager<_Ty>
{_Associated_state<_Ty>* _Assoc_state; bool _Get_only_once; 
// 当 本模板 作为 future        的父类时,_Get_only_once 为 true ;
// 当 本模板 作为 shared_future 的父类时,_Get_only_once 为 falsevoid wait()  {   _Assoc_state->_Wait();   }template <class _Rep, class _Per> // wait for durationfuture_status wait_for(const chrono::duration<_Rep, _Per>& _Rel_time){   return _Assoc_state->_Wait_for(_Rel_time);    }template <class _Clock, class _Dur> // wait until time pointfuture_status wait_until(const chrono::time_point<_Clock, _Dur>& _Abs_time) {   return _Assoc_state->_Wait_until(_Abs_time);  }
};template <class _Ty>
class _Associated_state  //用于管理关联同步状态的类
{virtual void _Wait() {  unique_lock<mutex> _Lock(_Mtx);   _Maybe_run_deferred_function(_Lock);while (!_Ready)     _Cond.wait(_Lock); }template <class _Rep, class _Per>   // wait for durationfuture_status _Wait_for( chrono::duration<_Rep, _Per>& _Rel_time)  {unique_lock<mutex> _Lock(_Mtx);if (_Has_deferred_function())    return future_status::deferred;if (_Cond.wait_for(_Lock, _Rel_time, _Test_ready(this)))     return future_status::ready;return future_status::timeout;}template <class _Clock, class _Dur>  // wait until time pointfuture_status _Wait_until( chrono::time_point<_Clock, _Dur>& _Abs_time) {unique_lock<mutex> _Lock(_Mtx);if (_Has_deferred_function())       return future_status::deferred;if (_Cond.wait_until(_Lock, _Abs_time, _Test_ready(this)))    return future_status::ready;return future_status::timeout;}
};

(63)

谢谢

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

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

相关文章

【MySQL】InnoDB引擎中的Compact行格式

目录 1、背景2、数据示例3、Compact解释【1】组成【2】头部信息【3】隐藏列【4】数据列 4、总结 1、背景 mysql中数据存储是存储引擎干的事&#xff0c;InnoDB存储引擎以页为单位存储数据&#xff0c;每个页的大小为16KB&#xff0c;平时我们操作数据库都是以行为单位进行增删…

Kylin麒麟操作系统 | 网络链路聚合配置(team和bond)

目录 一、理论储备1. 链路聚合 二、任务实施1. team模式2. bond模式 一、理论储备 1. 链路聚合 链路聚合是指将多个物理端口捆绑在一起&#xff0c;形成一个逻辑端口&#xff0c;以实现出/入流量在各成员端口中的负载分担。链路聚合在增加链路带宽、实现链路传输弹性和冗余等…

Linux中用户和用户管理详解

文章目录 Linux中用户和用户管理详解一、引言二、用户和用户组的基本概念1、用户账户文件2、用户组管理 三、用户管理操作1、添加用户2、设置用户密码3、删除用户 四、用户组操作1、创建用户组2、将用户添加到用户组 五、总结 Linux中用户和用户管理详解 一、引言 在Linux系统…

多进程并发跑程序:pytest-xdist记录

多进程并发跑程序&#xff1a;pytest-xdist记录 pytest -s E:\testXdist\test_dandu.py pytest -s testXdist\test_dandu.py pytest -s &#xff1a;是按用例顺序依次跑用例 pytest -vs -n auto E:\testXdist\test_dandu.py pytest -vs -n auto&#xff0c;auto表示以全部进程…

笔记--(Shell脚本04)、循环语句与函数

循环语句 1、for语句的结构 for 变量名 in 取值列表 do 命令序列 done for 收件人 in 邮件地址列表 do 发送邮件 done for i in {1..10} doecho $i done[rootlocalhost shell]# ./ce7.sh 1 2 ...... 9 101 #!/bin/bash2 3 for i in seq 1 104 do5 echo $i6 done[rootlocal…

用.Net Core框架创建一个Web API接口服务器

我们选择一个Web Api类型的项目创建一个解决方案为解决方案取一个名称我们这里选择的是。Net 8.0框架 注意&#xff0c;需要勾选的项。 我们找到appsetting.json配置文件 appsettings.json配置文件内容如下 {"Logging": {"LogLevel": {"Default&quo…

go引用包生成不了vendor的问题

比如我要引入github.com/jinzhu/gorm这个包. 1. 首先获取包 go get github.com/jinzhu/gorm 这时go.mod文件中也有这个包依赖信息了. 2. 然后构建vendor go mod vendor 结果发现vendor目录下没有生成对应的包, 而且modules.txt也注释掉这个包了. 原因是没有其进行引用, go…

36. Three.js案例-创建带光照和阴影的球体与平面

36. Three.js案例-创建带光照和阴影的球体与平面 实现效果 知识点 Three.js基础 WebGLRenderer WebGLRenderer 是Three.js中最常用的渲染器&#xff0c;用于将场景渲染到网页上。 构造器 new THREE.WebGLRenderer(parameters)参数类型描述parametersobject可选参数&#…

el-table表格嵌套子表格:展开所有内容;对当前展开行内容修改,当前行默认展开;

原文1 原文2 原文3 一、如果全部展开 default-expand-all"true" 二、设置有数据的行打开下拉 1、父table需要绑定两个属性expand-row-key和row-key <el-table:data"tableData":expand-row-keys"expends" //expends是数组&#xff0c;设置…

零基础微信小程序开发——小程序的宿主环境(保姆级教程+超详细)

&#x1f3a5; 作者简介&#xff1a; CSDN\阿里云\腾讯云\华为云开发社区优质创作者&#xff0c;专注分享大数据、Python、数据库、人工智能等领域的优质内容 &#x1f338;个人主页&#xff1a; 长风清留杨的博客 &#x1f343;形式准则&#xff1a; 无论成就大小&#xff0c;…

NOTEBOOK_11 汽车电子设备分享(工作经验)

汽车电子设备分享 摘要 本文主要列出汽车电子应用的一些实验设备和生产设备&#xff0c;部分会给予一定推荐。目录 摘要一、通用工具&#xff1a;二、测量与测试仪器2.1测量仪器2.2无线通讯测量仪器2.3元器件测试仪2.4安规测试仪2.5电源供应器2.6电磁兼容测试设备2.7可靠性环境…

linux centos 7 安装 mongodb7

MongoDB 是一个基于文档的 NoSQL 数据库。 MongoDB 是一个文档型数据库&#xff0c;数据以类似 JSON 的文档形式存储。 MongoDB 的设计理念是为了应对大数据量、高性能和灵活性需求。 MongoDB使用集合&#xff08;Collections&#xff09;来组织文档&#xff08;Documents&a…

opengl 着色器 (四)最终章收尾

颜色属性 在前面的教程中&#xff0c;我们了解了如何填充VBO、配置顶点属性指针以及如何把它们都储存到一个VAO里。这次&#xff0c;我们同样打算把颜色数据加进顶点数据中。我们将把颜色数据添加3个float值到vertices数组。我们将把三角形的三个角分别指定为红色、绿色和蓝色…

矩阵在资产收益(Asset Returns)中的应用:以资产回报矩阵为例(中英双语)

本文中的例子来源于&#xff1a; 这本书&#xff0c;网址为&#xff1a;https://web.stanford.edu/~boyd/vmls/ 矩阵在资产收益(Asset Returns)中的应用&#xff1a;以资产回报矩阵为例 在量化金融中&#xff0c;矩阵作为一种重要的数学工具&#xff0c;被广泛用于描述和分析…

arXiv-2024 | NavAgent:基于多尺度城市街道视图融合的无人机视觉语言导航

作者&#xff1a;Youzhi Liu, Fanglong Yao*, Yuanchang Yue, Guangluan Xu, Xian Sun, Kun Fu 单位&#xff1a;中国科学院大学电子电气与通信工程学院&#xff0c;中国科学院空天信息创新研究院网络信息系统技术重点实验室 原文链接&#xff1a;NavAgent: Multi-scale Urba…

校园点餐订餐外卖跑腿Java源码

简介&#xff1a; 一个非常实用的校园外卖系统&#xff0c;基于 SpringBoot 和 Vue 的开发。这一系统源于黑马的外卖案例项目 经过站长的进一步改进和优化&#xff0c;提供了更丰富的功能和更高的可用性。 这个项目的架构设计非常有趣。虽然它采用了SpringBoot和Vue的组合&am…

[计算机网络]ARP协议的故事:小明找小红的奇妙旅程

1.ARP小故事 在一个繁忙的网络世界中&#xff0c;每个设备都有自己的身份标识——MAC地址&#xff0c;就像每个人的身份证号码一样。在这个故事里&#xff0c;我们的主角小明&#xff08;主机&#xff09;需要找到小红&#xff08;目标主机&#xff09;的MAC地址&#xff0c;才…

arcgisPro将面要素转成CAD多段线

1、说明&#xff1a;正常使用【导出为CAD】工具&#xff0c;则导出的是CAD三维多线段&#xff0c;无法进行编辑操作、读取面积等。这是因为要素面中包含Z值&#xff0c;导出则为三维多线段数据。需要利用【复制要素】工具禁用M值和Z值&#xff0c;再导出为CAD&#xff0c;则得到…

vue+springboot+cas配置及cookie传递问题

cookie的注意事项 前边的文章已经介绍过cookie的基本信息&#xff0c;这里再次说明一点&#xff1a;cookie是无法进行跨域传递的&#xff0c;很多时候cookie无法设置和传递都是因为跨域问题&#xff0c;ip/端口不一致。 主要就是&#xff1a;被设置cookie和要传递cookie的地址…

simulink离散传递函数得到差分方程并用C语言实现

一. 创建连续时间的传递函数 G ( s ) s 2 217 s s 2 384 s 8989 G(s) \frac{s^2217s}{s^2384s8989} G(s)s2384s8989s2217s​ 二. 离散连续时间的传递函数G(s) 2.1 在matlab中用c2d函数双线性变换法离散G(s)&#xff0c; 下面是matlab脚本代码 % 创建连续时间传递函数 …