linux信号量初识
以下程序使用信号量控制程序运行
“信号”量
“变”量
/*信号量(semaphore)是变量,是一种特殊的变量。它仅取正值。
对信息号量的操作只有2种:等待(wait)和发送信号(signal)*/
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include <unistd.h>
#include <errno.h>
#define IPCKEY 0x111
#define LOCKFILE "/home/liuyi/comm/1.lock"
/*ftok的生成的key值依赖IPCKEY和LOCKFILE生成*/
/*arg for semctl systemcalls.*/
union semun {
int val;/*value for SETVAL*/
struct semid_ds *buf;/*buffer for IPC_STAT&IPC_SET*/
unsigned short *arrary;/*array for GETALL&SETALL*/
};
/*结构体说明
struct sembuf
{
unsigned short sem_num;
操作信号在信号集中的索引,第一个信号的索引是0
short sem_op;
如果其值为正数,
该值会加到现有的信号内含值中。通常用于释放所控资源的使用权;
如果sem_op的值为负数,会减去改信号内含的相应值,而其绝对值又大于信号的现值,
操作将会阻塞,直到信号值大于或等于sem_op的绝对值。通常用于获取资源的使用权;
如果sem_op的值为0,则操作将暂时阻塞,直到信号的值变为0。
short sem_flg;
信号操作标志,
IPC_NOWAIT 对信号的操作不能满足时,semop()不会阻塞,并立即返回,同时设定错误信息
SEM_UNDO 程序结束时(不论正常或不正常),保证信号值会被重设为semop()调用前的值。
这样做的目的在于避免程序在异常情况下结束时未将锁定的资源解锁,造成该资源永远锁定。
(重要的地方)
}; */
int main()
{
key_t key;
int sem_id;
union semun options;
struct sembuf lock_it;/*sembuf见说明*/
key = ftok(LOCKFILE,IPCKEY);
printf("key=[0x%x]\n",key);
sem_id = semget(key,1,IPC_CREAT|IPC_EXCL|0666);/*创建信号量集*/
/*key,刚才ftok产生的,若指定IPC_PRIVATE,则由系统分配。*/
/*1,信号量集中多少个信号量。*/
/*IPC_CREAT如果信号量集在系统内核中不存在,则创建信号量集。
IPC_EXCL当和 IPC_CREAT一同使用时,如果信号量集已经存在,则调用失败。*/
/*0666,该信号权限为666*/
/*ps:可以用ipcs –s命令来查看是否创建成功。ipcrm -s semid号来删除指定的信号量集。*/
printf("创建信号量集ID为[%d]\n",sem_id);
if(sem_id<0)
{
printf("信号量已经存在\n");
sem_id = semget(key,1,IPC_CREAT|0666);/*已经存在信号量集,取得信号量集ID*/
if(-1 == sem_id)
{
printf("取已存在的信号量集ID错误\n");
exit(-1);
}
printf("已存在的信号量集ID为[%d]\n",sem_id);
}
else
{
options.val =1;/*设信号量集中的 那个信号量值为1*/
semctl(sem_id,0,SETVAL,options);/*操作信号量集,SETVAL这里表示设置值*/
/*sem_id:信号量ID,也就是semget函数的返回值*/
/*0:要操作信号量在信号量集中的索引,从0开始*/
/*SETVAL:操作类型,SETALL设置信号量集中的所有的信号量的值,
SETVAL设置信号量集中的一个单独的信号量的值。等等*/
/*options:要设定信号量集中的信号量值 的联合体,可选*/
}
printf("信号集ID sem_id=[%d] \n",sem_id);
int i = semctl(sem_id,0,GETVAL);/*获取索引为0的位置的信号量的值*/
printf("1索引为0的位置的信号量的值为[%d]\n",i);
lock_it.sem_num =0; /*索引*/
lock_it.sem_op = -1;/*设成-1,就是将信号量的值减去1*/
lock_it.sem_flg = SEM_UNDO;/*程序结束后还原信号量的值*/
semop(sem_id,&lock_it,1);/*操作信号量,使信号量的值减去abs(lock_it.sem_op)*/
/*ps:如果当前信号量的值小于abs(lock_it.sem_op),会阻塞,直到当前信号量的值不
小于abs(lock_it.sem_op)时候才会执行(靠外部程序改变当前信号量的值)*/
i = semctl(sem_id,0,GETVAL);/*打印操作后的信号量值*/
printf("2索引为0的位置的信号量的值为[%d]\n",i);
/*这里开始就是你干的私活了*/
int j;
scanf("%d",&j);
printf("finish\n");
return 0;
}
linux信号量初识的更多相关文章
- Linux信号量详解
1.什么是信号量信号量是一种特殊的变量,访问具有原子性.只允许对它进行两个操作:1)等待信号量当信号量值为0时,程序等待:当信号量值大于0时,信号量减1,程序继续运行.2)发送信号量将信号量值加1. ...
- Java中处理Linux信号量
为了防止无良网站的爬虫抓取文章,特此标识,转载请注明文章出处.LaplaceDemon/ShiJiaqi. http://www.cnblogs.com/shijiaqi1066/p/5976361. ...
- Linux信号量同步共享内存实验.
Linux信号量同步共享内存实验. Linux信号量同步共享内存实验. 简述 程序流程 信号量和共享内存的系统函数 信号量系统函数及接口 共享内存系统函数及接口 写程序 读程序 简述 本文主要内容是自 ...
- Linux入门——初识Linux
Linux入门——初识Linux 摘要:本文主要说明了Linux是什么,Linux发展历史,以及同Linux系统有关的一些基本知识. 简介 操作系统 Linux系统同Windows系统.Mac系统一样 ...
- linux信号量之进程间同步
概念 linux信号量: 允许多个线程同时进入临界区,可以用于进程间的同步. 和互斥锁(mutex)的区别: 互斥锁只允许一个线程进入临界区. 所在头文件: semaphore.h 主要函数 初始化函 ...
- Linux 信号量同步编程
前一篇文章概述了Linux 系统中信号量互斥编程,这篇文章正好是前一篇的姊妹篇----信号量同步.说它们是姊妹篇是因为它们都是利用了内核的信号量机制实现了进程间的通信.因为两者所解决的问题不同,因此它 ...
- Linux 信号量互斥编程
所谓信号量,其实就是一个数字.内核给这个数字赋予一定的含义,让它等于不同的值时所表示的意义不同.这样就可以用它来标示某种资源是否正被使用.信号的分类其实挺多的,主要还是二值和计数器.这里讨论二值 现在 ...
- [转] linux 信号量之SIGNAL
我们可以使用kill -l查看所有的信号量解释,但是没有看到SIGNAL 0的解释. [root@testdb~]# kill -l 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) ...
- linux信号量与完成量
信号量: 是用于保护临界区的一种常用方法,它的使用和自旋锁类似.与自旋锁相同,只有得到信号量的进程才能执行 临界区的代码.但是与自旋锁不同的是,当获取不到信号量时,进程不会原地打转而是进入休眠等 ...
随机推荐
- Mybatis 为什么不要用二级缓存
https://www.cnblogs.com/liouwei4083/p/6025929.html mybatis 二级缓存不推荐使用 一 mybatis的缓存使用. 大体就是首先根据你的sqlid ...
- sqlserver导入导出数据库结构及创建用户分配权限
1.创建用户分配权限 https://www.cnblogs.com/jennyjiang-00/p/5803140.html 2.sqlserver2008导出表结构和表数据 导出表结构 htt ...
- Hive启动异常
[root@host ~]# hivewhich: no hbase in (/root/app/apache-maven-3.5.2/bin:/usr/local/sbin:/usr/local/b ...
- openlayers-热地图加载(完整版及代码)
//地圖加載function mapInit(data){ //底图// var raster = new ol.layer.Tile({// source: new ol.source.Stamen ...
- springboot sybase 数据库
依赖:(驱动) <!-- https://mvnrepository.com/artifact/net.sourceforge.jtds/jtds --> <dependency&g ...
- redis详解(四)-- 高可用分布式集群
一,高可用 高可用(High Availability),是当一台服务器停止服务后,对于业务及用户毫无影响. 停止服务的原因可能由于网卡.路由器.机房.CPU负载过高.内存溢出.自然灾害等不可预期的原 ...
- Redis 安装 和 启动
Redis下载官网 http://download.redis.io/releases/ 本人下载了stable版 1:安装步骤 ># wget http://download.redis.i ...
- UI5-文档-2.2-使用SAP Web IDE开发应用程序
SAP Web IDE是一种基于Web的开发环境,它是为使用最新的创新开发SAPUI5复杂的应用程序.开发和扩展SAP Fiori应用程序.开发移动混合应用程序以及使用插件和模板扩展SAP Web I ...
- LVS原理以及配置
安装好ipvsadm后需要查看内核是否加载了ip_vs模块儿,如果没有需要手动执行ipvsadm进行加载: # ipvsadm # lsmod |grep ip_vs # rmmod ip_vs_rr ...
- MeToo, one year on
表示转折/让步关系:but, however, nevertheless, whereas, although, despite, in spite of, still 表示比较或对比关系:simil ...