信号量集用于对存在竞争的资源加锁

1.semId=semget(key,nsems,semflg)

  key:为信号量集名称,可以指定为0455等数字,也可以为PC_PRIVATE

  nsems:创建几个信号量

  semflg:创建并给权限,如(IPC_CREAT | 0600);

2.semctl(semId,semnum,cmd,...)//

  2.1初始化信号量集  

  semctl(semId,num,SETVAL,1)  将semId的第num个信号量设置为1;semvalue

  2.2删除信号量集

  semctl(semId,0,IPC_RMID)    删除信号量集semId

  .......

3. 锁的操作

  semop(semId,&buf,1)/////能做则做,不能做则阻塞等待

  锁操作是将要操作的信号放到一个结构体中 struct sembuf   buf;

  buf.sem_num:对第几个信号操作

  buf.sem_op:  有三种情况  大于0(释放资源)   小于0(申请资源)     等于0(等0操作)

  buf.sem_flg:  是否阻塞

  semop(semId,&buf,1);操作1个这样的buf

·

  semtimeop()//能做则做,不能做则阻塞一段时间后返回,常用于超时等待

代码示例

//等零操作:子进程执行10次 父进程执行一次
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include <sys/wait.h>

#define      NR     1

int p_lock(int semId);
void v_unlock(int semId);
void w_zero(int semId);

int main(void)
{
    int semId,ret;
    pid_t pid;

semId=semget(IPC_PRIVATE,NR,0600);
    if(semId==-1)
    {
        perror("semget");
        return 1;
    }
    //init sem value
    ret=semctl(semId,0,SETVAL,0);
    if(ret==-1)
    {
        perror("set sem val");
        semctl(semId,0,IPC_RMID);
        return 2;
    }

//create child process  继承semId
    pid=fork();
    if(pid==-1)
    {
        semctl(semId,0,IPC_RMID);
        perror("fork");
        return 3;
    }
    else if(pid==0)//child
    {
        int count=1;
        while(1)
        {
            p_lock(semId);
            printf("child do %dth\n",count);
            count++;
            sleep(1);
        }
        exit(0);
    }
    //aprent
    while(1)
    {
        w_zero(semId);
        printf("parent do....\n");

v_unlock(semId);
    }

wait(NULL);
 
    semctl(semId,0,IPC_RMID);
    return 0;
}
int p_lock(int semId)
{
    struct sembuf  buf[1];
    buf[0].sem_num=0;//第几个
    buf[0].sem_op =-1;//怎么操作(1.op>0 指释放资源   2.op<0 申请资源  3.op==0等大资源为0)
    buf[0].sem_flg=0; //IPC_NOWAIT

return semop(semId,buf,1);
}

void v_unlock(int semId)
{
    struct sembuf  buf;
    buf.sem_num=0;//第几个
    buf.sem_op =10;//怎么操作(1.op>0 指释放资源   2.op<0 申请资源  3.op==0等大资源为0)
    buf.sem_flg=0; //IPC_NOWAIT

semop(semId,&buf,1);
}
void w_zero(int semId)
{
    struct sembuf  buf;
    buf.sem_num=0;//第几个
    buf.sem_op =0;//怎么操作(1.op>0 指释放资源   2.op<0 申请资源  3.op==0等大资源为0)
    buf.sem_flg=0; //IPC_NOWAIT

semop(semId,&buf,1);

}

IPC之——信号量集的更多相关文章

  1. IPC之——信号量集(多个信号量)

    如果两个进程不仅需要同步,还要保证先后执行顺序,就要用两个信号量(互斥锁)来解决 //栅栏模型:实现以下框架中的四个子进程 所有进程做完任务后 在一起执行下一次  #include <stdio ...

  2. System V IPC 之信号量

    本文继<System V IPC 之共享内存>之后接着介绍 System V IPC 的信号量编程.在开始正式的内容前让我们先概要的了解一下 Linux 中信号量的分类. 信号量的分类 在 ...

  3. Linux IPC 之信号量

    信号量(也叫信号灯)是一种用于提供不同进程间或一个给定进程的不同线程间同步手段的原语. 信号量是进程/线程同步的一种方式,有时候我们需要保护一段代码,使它每次只能被一个执行进程/线程运行,这种工作就需 ...

  4. IPC之信号量

    无名信号量 POSIX标准提出了有名信号量和无名信号量来同步进程和线程,而linux(2.6以前)只实现了无名信号量. sem_overview中有详细介绍:man 7 sem_overview. S ...

  5. IPC进程间通信---信号量

    信号量 信号量:信号量是一个计数器,常用于处理进程或线程的同步问题,特别是对于临界资源访问的同步.临界资源可以 理解为在某一时刻只能由一个进程或线程操作的资源,这里的资源可以是一段代码.一个变量或某种 ...

  6. linux IPC的信号量

    信号量相关函数原型 获得一个信号量ID #include <sys/types.h> #include <sys/ipc.h> #include <sys/sem.h&g ...

  7. ucos信号量集源码分析

    在实际的应用之中,一个任务经常需要等待多个信号量的同时生效,或者说任务需要根据多个信号量的组合作用的结果来决定任务的运行方式,为了实现这种多信号量组合的功能,ucos实现了信号量集的特殊结构. 信号量 ...

  8. μC/OS-II 信号量集

    简介 在实际应用中,任务常常需要与多个事件同步,即要根据多个信号量组合作用的结果来决定任务的运行方式.μC/OS-II 为了实现多个信号量组合的功能定义了一种特殊的数据结构--信号量集. 信号量集所能 ...

  9. 【iCore4 双核心板_uC/OS-II】例程十:信号量集

    一.实验说明: 在实际应用中,任务常常需要与多个事件同步,即要根据多个信号量组合作用的结果来决定任务的运行方式.UCOSII为了实现多个信号量组合的功能定义了一种特殊的数据结构——信号量集. 二.实验 ...

随机推荐

  1. 18 12 06 sql 的 基本语句 查询 条件查询 逻辑运算符 模糊查询 范围查询 排序 聚合函数 分组 分页 连接查询 自关联 子查询

    -- 数据的准备 -- 创建一个数据库 create database python_test charset=utf8; -- 使用一个数据库 use python_test; -- 显示使用的当前 ...

  2. ping内网服务器

    cat ping.sh#!/bin/baship="192.168.1."lastip=(200201202210211212220221222) #ip列表 可以继续添加 ps ...

  3. .NET技术-5.0. NETCORE设置返回数据字段的大小写

    .NET技术-5.0. NETCORE设置返回数据字段的大小写 问题来源于我写了一个接口,接口的返回类型是JsonResult,但是对接之后反应返回结果的首字母全小写了, 后来查了写资料返现.net ...

  4. [转]分析zookeeper能做什么

    Zookeeper是hadoop的一个子项目,虽然源自hadoop,但是我发现zookeeper脱离hadoop的范畴开发分布式框架的运用越来越多.今天我想谈谈zookeeper,本文不谈如何使用zo ...

  5. 池ThreadPoolExecutor使用简介

    public static void main(String[] args) { //guava 创建线程池 //https://blog.csdn.net/chinabestchina/articl ...

  6. 【One by one系列】一步步学习TypeScript

    TypeScript Quick Start 1.TypeScript是什么? TypeScript是ES6的超集. TS>ES7>ES6>ES5 Vue3.0已经宣布要支持ts,至 ...

  7. 汪慧和201771010123《面向对象程序设计(Java)》第三周学习总结

    1.实验目的与要求 (1)进一步掌握Eclipse集成开发环境下java程序开发基本步骤: (2)熟悉PTA平台线上测试环境: (3)掌握Java语言构造基本程序语法知识(ch1-ch3): (4)利 ...

  8. HGP|VCG|UK10K|中科院职业人群队列研究计划|药物基因组学

    全球性计划:表观组计划:肝计划 测1000人的变异level HGP计划三个阶段,范围逐步扩大和深化. Pilot:deep sequence---low coverage Phase 1 Phase ...

  9. CSS——fixed 固定定位相对于父容器

    position:fixed 固定定位 用 left top 都是相对于浏览器的. 我今天想给网页做一个固定定位的导航 偶然间发现.可以用margin 相对于父容器定位. 小伙伴们可以试试. 不用le ...

  10. shell的一些一句话东西

    shell的一些一句话东西 2010-09-10 11:22:58|  分类: linux shell |  标签:shell  linux  |举报|字号 订阅     time -p [程序] 可 ...