当前位置: 首页 > news >正文

线程的控制

互斥

概念

互斥:在多线程中对临界资源(公共资源)的排他性访问。
互斥机制 >>互斥锁  >>保证临界资源的访问控制。

通过使用互斥锁,可以确保某一时刻只有一个线程能够访问临界资源,从而避免竞争条件(race conditions)的发生

pthread_mutex_t   mutex;
互斥锁类型        互斥锁变量 内核对象

框架:
 定义互斥锁 >>初始化锁 >>加锁 >>解锁 >>销毁
****                                        ***      ***


定义

pthread_mutex_t   mutex;

定义变量(一般定义为全局变量)

初始化锁

int pthread_mutex_init(pthread_mutex_t *mutex,
const pthread_mutexattr_t *attr);
  • 功能

将已经定义好的互斥锁初始化。

  • 参数

mutex 要初始化的互斥锁
atrr  初始化的值,一般是NULL表示默认锁

  • 返回值

成功 0        失败 非零


加锁

int pthread_mutex_lock(pthread_mutex_t *mutex);
  • 功能

用指定的互斥锁开始加锁代码
加锁后的代码到解锁部分的代码属于原子操作(最小操作、不可再分割的操作),
在加锁期间其他进程/线程都不能操作该部分代码(这部分代码应该尽可能短)
如果该函数在执行的时候,mutex已经被其他部分使用则代码阻塞。

  • 参数

 mutex 用来给代码加锁的互斥锁

  • 返回值

成功 0        失败 非零

加锁时机

  • 访问共享资源时

在任何线程需要读写共享资源(如全局变量、共享数据结构、文件等)之前,应该先上锁。这样可以防止其他线程同时访问这个资源,导致数据竞争或不一致的问题。

例如:在一个银行账户系统中,多个线程同时更新账户余额时,应在修改余额之前锁定。

  • 进入临界区时

临界区是指代码中可能被多个线程并发访问,且访问时需要互斥的部分。临界区通常是需要同步的代码块,在进入临界区前应上锁。

例如:在生产者-消费者模型中,生产者和消费者访问同一个缓冲区时,需要在进入缓冲区的操作代码之前上锁。

  • 检查或修改共享状态时

如果线程需要检查或修改某个共享状态(如队列的长度、任务的状态等),应该在检查或修改之前上锁,以确保其他线程不会在中间更改状态。

例如:在线程池中,当线程检查是否有任务可用时,应先上锁以确保状态一致


解锁

int pthread_mutex_unlock(pthread_mutex_t *mutex);
  • 功能

将指定的互斥锁解锁。
解锁之后代码不再排他访问,一般加锁解锁同时出现。

  • 参数

用来解锁的互斥锁

  • 返回值

成功 0        失败 非零

解锁时机

  • 离开临界区时

当线程完成了对共享资源的访问或完成了临界区的操作,应立即解锁。这样其他等待的线程可以获取锁并继续执行,避免死锁或资源饥饿。

例如:在修改完共享数据之后,线程应立即解锁以释放互斥锁,让其他线程可以访问共享数据。

  • 操作完成时

如果锁是为了保护某个操作的原子性(即操作不可分割),那么在操作完成后应解锁。

例如:如果线程锁定了一个文件进行读写操作,在操作完成后应解锁,以便其他线程可以访问文件。

  • 上锁:在访问共享资源、进入临界区、或检查/修改共享状态之前上锁
  • 解锁:在离开临界区、操作完成后立即解锁

 销毁

 int pthread_mutex_destroy(pthread_mutex_t *mutex);
  • 功能

使用互斥锁完毕后需要销毁互斥锁

  • 参数

mutex 要销毁的互斥锁

  • 返回值

成功  0        失败  非零
 

trylock

int pthread_mutex_trylock(pthread_mutex_t *mutex);
  • 功能

类似加锁函数效果,唯一区别就是不阻塞

  • 参数

mutex 用来加锁的互斥锁

  • 返回值

成功 0        失败 非零
当锁已经被占用时,通常返回 E_AGAIN

同步

线程的同步 

同步 :有一定先后顺序的对资源的排他性访问。

同步产生原因:互斥锁可以控制排他访问但没有次序。

linux下的线程同步 >>信号量机制 >>semaphore.h   posix 
sem_open();


信号量的分类:
1、无名信号量 ——线程间通信
2、有名信号量 ——进程间通信

框架:
信号量的定义>>信号量的初始化 >>信号量的PV操作>>信号量的销毁
 


信号量的定义 

semaphore 
sem_t            sem;
信号量的类型     信号量的变量

信号量的初始化

int sem_init(sem_t *sem, int pshared, unsigned int value);
  • 功能

将已经定义好的信号量赋值。

  • 参数

sem 要初始化的信号量
pshared = 0 ;表示线程间使用信号量
             !=0 ;表示进程间使用信号量
value 信号量的初始值,一般无名信号量
          都是二值信号量,0 1 
          0 表示红灯,进程暂停阻塞
          1 表示绿灯,进程可以通过执行

返回值:成功  0        失败  -1;


信号量的PV 操作

P :申请资源——申请一个二值信号量 (0or1)
V :释放资源——释放一个二值信号量

P操作对应函数 :sem_wait();
V操作对应函数 :sem_post();
 

sem_wait()

int sem_wait(sem_t *sem);
  • 功能

判断当前sem信号量是否有资源可用。
  如果sem有资源(==1),则申请该资源,程序继续运行
  如果sem没有资源(==0),则线程阻塞等待,一 旦有资源
  则自动申请资源并继续运行程序。

  注意:sem 申请资源后会自动执行 sem = sem - 1;(可用作计数信号量)

  • 参数

sem 要判断的信号量资源

  • 返回值

成功 0         失败 -1

sem_post()

int sem_post(sem_t *sem);
  • 功能

函数可以将指定的sem信号量资源释放
  并默认执行,sem = sem+1;
  线程在该函数上不会阻塞。

  • 参数

sem 要释放资源的信号量

  • 返回值

成功 0        失败 -1;



信号量的销毁

int sem_destroy(sem_t *sem);
  • 功能

使用完毕将指定的信号量销毁

  • 参数

sem要销毁的信号量

  • 返回值

死锁的产生

产生死锁的原因

主要是:
(1) 因为系统资源不足。
(2) 进程运行推进的顺序不合适。
(3) 资源分配不当等。
如果系统资源充足,进程的资源请求都能够得到满足,死锁出现的可能性就很低,否则
就会因争夺有限的资源而陷入死锁。其次,进程运行推进顺序与速度不同,也可能产生死锁。

产生死锁的四个必要条件

(1) 互斥条件:一个资源每次只能被一个进程(线程)使用。
(2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
(3) 不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
(4) 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

相关文章:

线程的控制

互斥 概念 互斥:在多线程中对临界资源(公共资源)的排他性访问。 互斥机制 >>互斥锁 >>保证临界资源的访问控制。 通过使用互斥锁,可以确保某一时刻只有一个线程能够访问临界资源,从而避免竞争条件(race condition…...

WPS宏实现Sheet页拆分功能

源表格首列名称中一样的分别创建该名称的Sheet页,首先把首列复制导致Sheet2页,根据去重后的值创建新的Sheet页,把源表格数据复制到新建的Sheet页,遍历删除不需要的留下需要的就完成了。 function JIn521() { //设置工作…...

【图像超分】论文精读:AdaBM: On-the-Fly Adaptive Bit Mapping for Image Super-Resolution

第一次来请先看这篇文章:【超分辨率(Super-Resolution)】关于【超分辨率重建】专栏的相关说明,包含专栏简介、专栏亮点、适配人群、相关说明、阅读顺序、超分理解、实现流程、研究方向、论文代码数据集汇总等) 文章目录 前言Abstract1. Introduction2. Related works3. Pr…...

深信服应届生客户经理面试经验分享

吉祥知识星球http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247485367&idx1&sn837891059c360ad60db7e9ac980a3321&chksmc0e47eebf793f7fdb8fcd7eed8ce29160cf79ba303b59858ba3a6660c6dac536774afb2a6330#rd 《网安面试指南》http://mp.weixin.qq.com/s?…...

什么是应用交付控制器(ADC)

什么是应用交付控制器(ADC) 应用交付控制器(ADC)是一种网络设备,可帮助管理和优化面向最终用户的基于web的应用程序和服务的交付,根据服务器可用性、网络拥塞和用户位置等因素,将传入的web流量…...

旅游管理系统

TOC springboot0748旅游管理系统 第1章 绪论 1.1课题背景 计算机的普及和互联网时代的到来使信息的发布和传播更加方便快捷。用户可以通过计算机上的浏览器访问多个应用系统,从中获取一些可以满足用户需求的管理系统。网站系统有时更像是一个大型“展示平台”&a…...

AVI-Talking——能通过语音生成很自然的 3D 说话面孔

概述 论文地址:https://arxiv.org/pdf/2402.16124v1.pdf 逼真的人脸三维动画在娱乐业中至关重要,包括数字人物动画、电影视觉配音和虚拟化身的创建。以往的研究曾试图建立动态头部姿势与音频节奏之间的关联模型,或使用情感标签或视频剪辑作…...

走进虚拟机逃逸技术之VMware Escape漏洞CVE-2023-20872复现

走进虚拟机逃逸技术之VMware Escape漏洞CVE-2023-20872复现 技术分享 技术分享 起初,为了学习虚拟机逃逸相关技术,也为了搞懂硬件虚拟化。于是请教了某巨佬后告诉我一本书,看完之后为了验证我理解到的硬件虚拟化及虚拟化逃逸原理是否正确&am…...

leetcode118. 杨辉三角,老题又做

leetcode118. 杨辉三角 给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中,每个数是它左上方和右上方的数的和。 示例 1: 输入: numRows 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]] 示例 2: 输入: numRows 1…...

进程(一)(22)

1.进程是什么 进程是程序执行的过程,会去分配内存资源,cpu的调度。正在运行的程序叫进程。 并发:同一时刻可以同时完成多个任务。 进程: 是操作系统对正在运行的程序的抽象。进程不仅包括程序的代码,还包括程序的执行状态、内存…...

Excel“取消工作表保护”忘记密码并恢复原始密码

文章目录 1.前言2.破解步骤3. 最终效果4.参考文献 1.前言 有时候别人发来的Excel中有些表格不能编辑,提示如下,但是又不知道原始密码 2.破解步骤 1、打开您需要破解保护密码的Excel文件; 2、依次点击菜单栏上的视图—宏----录制宏&#xf…...

WPS关闭后,进程依然在后台运行的解决办法

问题 wps启动后 在启动wps后,什么都不做,打开进程管理器,发现居然运行了3个wps进程: win10只会显示wps进程: win11显示比较准确: 关闭后 在关闭wps,再去任务管理器查看,发现在…...

SQL每日一练-0816

今日SQL题:计算每个项目的年度收入增长率 难度系数:🌟☆☆☆☆☆☆☆☆☆ 1、题目要求 计算每个项目每年的收入总额,并计算项目收入环比增长率。找出每年收入增长率最高的项目。输出结果显示年份、项目ID、项目名称、项…...

直方图均衡化

概念 直方图均衡化是图像处理领域中利用图像直方图对对比度进行调整的方法,通过拉伸像素强度分布范围来增强图像对比度。 原理 均衡化指的是把一个分布 (给定的直方图) 映射 到另一个分布 (一个更宽更统一的强度值分布),从而令强度值分布会在整个范围内…...

Golang | Leetcode Golang题解之第342题4的幂

题目: 题解: func isPowerOfFour(n int) bool {return n > 0 && n&(n-1) 0 && n%3 1 }...

数学建模学习(116):全面解析梯度下降算法及其在机器学习中的应用与优化

文章目录 1.梯度下降简介1.1 梯度下降的数学原理1.2 学习率的选择2 梯度下降变体3.梯度下降优化器3.1 动量法(Momentum)3.2 AdaGrad3.3 RMSprop3.4 Adam3.5 Python 使用不同优化器训练线性回归模型4.案例:使用梯度下降优化加利福尼亚房价预测模型4.1. 数据准备4.2. 模型训练…...

[mysql][sql]mysql查询表大小

select table_schema as 数据库, table_name as 表名, table_rows as 记录数, truncate(data_length/1024/1024, 2) as 数据容量(MB), truncate(index_length/1024/1024, 2) as 索引容量(MB) from information_schema.tables where 11 and table_schemadb001 order by table_ro…...

8.16 mysql主从数据库(5.7版本)与python的交互及mycat

mysql数据库基本操作: [rootm ~]# tar -xf mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz 解压压缩包 [rootm ~]# ls anaconda-ks.cfg mysql-5.7.44-linux-glibc2.12-x86_64 mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz [rootm ~]# cp -r mysql-5.7.44-lin…...

项目问题 | CentOS 7停止维护导致yum失效的解决办法

目录 centos停止维护意味着yum相关源伴随失效。 报错: 解决方案:将图中四个文件替换掉/etc/yum.repos.d/目录下同名文件 资源提交在博客头部,博客结尾也提供文件源码内容 CentOS-Base.repo CentOS-SCLo-scl.repo CentOS-SCLo-scl-rh.rep…...

【Docker】Docker Compose(容器编排)

一、什么是 Docker Compose docker-compose 是 Docker 官方的开源项目,使用 python 编写,实现上调用了 Docker 服务的 API 进行容器管理及编排,其官方定义为定义和运行多个 Docker 容器的应用。 docker-compose 中有两个非常重要的概念&…...

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...

DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI

前一阵子在百度 AI 开发者大会上,看到基于小智 AI DIY 玩具的演示,感觉有点意思,想着自己也来试试。 如果只是想烧录现成的固件,乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外,还提供了基于网页版的 ESP LA…...

css3笔记 (1) 自用

outline: none 用于移除元素获得焦点时默认的轮廓线 broder:0 用于移除边框 font-size&#xff1a;0 用于设置字体不显示 list-style: none 消除<li> 标签默认样式 margin: xx auto 版心居中 width:100% 通栏 vertical-align 作用于行内元素 / 表格单元格&#xff…...

保姆级教程:在无网络无显卡的Windows电脑的vscode本地部署deepseek

文章目录 1 前言2 部署流程2.1 准备工作2.2 Ollama2.2.1 使用有网络的电脑下载Ollama2.2.2 安装Ollama&#xff08;有网络的电脑&#xff09;2.2.3 安装Ollama&#xff08;无网络的电脑&#xff09;2.2.4 安装验证2.2.5 修改大模型安装位置2.2.6 下载Deepseek模型 2.3 将deepse…...

基于Java+MySQL实现(GUI)客户管理系统

客户资料管理系统的设计与实现 第一章 需求分析 1.1 需求总体介绍 本项目为了方便维护客户信息为了方便维护客户信息&#xff0c;对客户进行统一管理&#xff0c;可以把所有客户信息录入系统&#xff0c;进行维护和统计功能。可通过文件的方式保存相关录入数据&#xff0c;对…...

Java毕业设计:WML信息查询与后端信息发布系统开发

JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发&#xff0c;实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构&#xff0c;服务器端使用Java Servlet处理请求&#xff0c;数据库采用MySQL存储信息&#xff0…...

处理vxe-table 表尾数据是单独一个接口,表格tableData数据更新后,需要点击两下,表尾才是正确的

修改bug思路&#xff1a; 分别把 tabledata 和 表尾相关数据 console.log() 发现 更新数据先后顺序不对 settimeout延迟查询表格接口 ——测试可行 升级↑&#xff1a;async await 等接口返回后再开始下一个接口查询 ________________________________________________________…...

(一)单例模式

一、前言 单例模式属于六大创建型模式,即在软件设计过程中,主要关注创建对象的结果,并不关心创建对象的过程及细节。创建型设计模式将类对象的实例化过程进行抽象化接口设计,从而隐藏了类对象的实例是如何被创建的,封装了软件系统使用的具体对象类型。 六大创建型模式包括…...

【前端异常】JavaScript错误处理:分析 Uncaught (in promise) error

在前端开发中&#xff0c;JavaScript 异常是不可避免的。随着现代前端应用越来越多地使用异步操作&#xff08;如 Promise、async/await 等&#xff09;&#xff0c;开发者常常会遇到 Uncaught (in promise) error 错误。这个错误是由于未正确处理 Promise 的拒绝&#xff08;r…...

聚六亚甲基单胍盐酸盐市场深度解析:现状、挑战与机遇

根据 QYResearch 发布的市场报告显示&#xff0c;全球市场规模预计在 2031 年达到 9848 万美元&#xff0c;2025 - 2031 年期间年复合增长率&#xff08;CAGR&#xff09;为 3.7%。在竞争格局上&#xff0c;市场集中度较高&#xff0c;2024 年全球前十强厂商占据约 74.0% 的市场…...