Linux操作系统——什么叫做信号量?

2024-02-29 05:04

本文主要是介绍Linux操作系统——什么叫做信号量?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概念理解

信号量的本质是一把计数器

在我们了解信号量之前,我们先来了解以下几个概念,在我们学习前面进程间通信的时候,我们经常说到一句话叫做,进程间通信的前提是让不同的进程看到同一份资源。

多个执行流看到的同一份资源,叫做公共资源。就比如说我们之前学的不管是命名管道,还是匿名管道,两个不同的进程看到的都是公共的缓冲区资源,还是我们之前写的共享内存,它的公共资源就是我们所建立的共享内存的公共资源,还是我们多个进程看到的公共的消息队列资源,不管我们怎么说,其实我们发现一个比较特殊的现象就是,目前的这些资源都是由操作系统提供的,这也是应该的,因为我们要保证进程具有独立性,那么就不可能让一个进程访问另一个进程所属的资源,所以肯定存在着第三方提供的资源,那么这样的公共资源就伴生着下一个问题,那就是公共资源访问的问题,不同的进程,A进程想读,B进程也想读,A进程想写,B进程也想写,所以我们在多个进程同时访问公共资源的同时就会伴随着一些问题发生,就是如果A想写,B也想写,那就很容易造成覆盖问题,而并发访问也就一定会导致产生数据不一致的问题,那就决定了我们必须要将公共资源保护起来,然后就会谈到同步和互斥。

互斥:任何一个时刻只允许一个执行流(进程)访问公共资源,加锁完成。

同步:多个执行流的时候,按照一定的顺序执行。

被保护起来的公共资源:临界资源。 (相对应的就有非临界资源)

访问该临界资源的代码,叫做临界区。(相对应的就有非临界区)

维护临界资源其实就是在维护临界区。

原子性:要么不做,要么做完。

如何理解信号量?

就拿看电影这个例子来说,我们去电影院看电影,电影院里面有公共座位,那么这些座位是当我们坐下去的时候才属于我,还是当我们买到票的那一刻属于我呢?所以在看电影的时候,当我们买到票的时候座位就属于我们了。所以这里我们的电影院和座位就是我们现实生活中多个人共享的,本身就是公共资源,电影院是支持多个人共享同一份资源(电影)的,为了合理的电影院中的座位,我们买票其实就是电影院座位公共资源给我们派发的过程,只要我买到了票,那么那个座位只要是电影在放映期间,哪怕我不去,那个座位依然属于我,电影院里如果有100个座位,绝对不可能卖101张票,而我们买票的本质:是对资源的预定机制!  那么我们怎么保证只卖100张票呢?此时我们就可以提供一把计数器 int count = 100; 而每卖出去一张票,我们的计数器就--,count--。所以这个count计数器就起到一个表示公共资源的个数。而公共资源可能会被拆分成多份资源。我们把这种用来衡量公共资源的数目,用来达到对公共资源分配的一个目的的这种计数器,我们将其称之为信号量。

信号量:表示资源数目的计数器,每一个执行流想访问公共资源内的某一份资源,不应该让执行流直接访问,而是先申请信号量资源,其实就是先对信号量计数器进行减减操作。本质上,只要减减成功,完成了对资源的预定机制。

如果申请不成功呢?执行流被挂起阻塞。

那么我们下面来分析细节问题:

1.要想访问公共资源意味着,每个进行先看到同一个信号量资源 --- 那么这个信号量资源只能由操作系统提供了,纳入到了IPC体系。

2.信号量的本质也是公共资源,我们前面说的信号量就是用来保护公共资源的,但是现在连信号量都变成了公共资源了,也就是变成了被保护对象了,但是如果信号量资源自己都保护不了又怎么保护别人呢?好在信号量资源并不复杂,只需要++,--操作,所以对信号量进行操作必须是原子的。所以这样就不会出现其他情况了,我们把--操作叫做P操作,++操作叫做V操作。

3.如果信号量资源申请成功了就可以直接往后走了,而如果申请失败了就会被挂起,我们今天可以这么理解信号量,我们理解单个信号量

//单个信号量
struct sem
{int count;task_struct *wait_queue;
}

这篇关于Linux操作系统——什么叫做信号量?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/757654

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。

如何编写Linux PCIe设备驱动器 之二

如何编写Linux PCIe设备驱动器 之二 功能(capability)集功能(capability)APIs通过pci_bus_read_config完成功能存取功能APIs参数pos常量值PCI功能结构 PCI功能IDMSI功能电源功率管理功能 功能(capability)集 功能(capability)APIs int pcie_capability_read_wo