Linux下进程间通信的方法--信号量

这里的信号量主要是在不同的进程之间使用。
需要四个操作

  1. P操作
  2. V操作
  3. 以及通过semctl调用command参数设置SETVAL来初始化信号量,在使用信号量之前必须要这么做.
  4. 并且可以通过semctl调用command设置为IPC_RMID来删除信号量ID:

因为库里没有定义union semun,因此需要自己定义.

用到信号量的三个函数

  1. semget 用来创建一个新信号量或者取得一个已有信号量的键
  2. semop 用来改变信号量的值
  3. semctl 用来直接控制信号量信息,比如semop之前必须先用semctl给个初值
#include<unistd.h>
#include<stdlib.h>
#include<stdio.h>

#include<sys/sem.h>

union semun
{
    int val;
    struct semid_ds *buf;
    unsigned short int *array;
    struct seminfo *__buf;
};

static int set_semvalue(void);
static void del_semvalue(void);
static int semaphore_p(void);
static int semaphore_v(void);

static int sem_id;

static int set_semvalue(void)
{
    union semun sem_union;
    sem_union.val=1;
    semctl(sem_id,0,SETVAL,sem_union);
}

static void del_semvalue(void)
{
    union semun sem_union;
    semctl(sem_id,0,IPC_RMID,sem_union);
}

static int semaphore_p(void)
{
    struct sembuf sem_b;
    sem_b.sem_num=0;
    sem_b.sem_op=-1;
    sem_b.sem_flg=SEM_UNDO;//auto release
    semop(sem_id,&sem_b,1);
}

static int semaphore_v(void)
{
    struct sembuf sem_b;
    sem_b.sem_num=0;
    sem_b.sem_op=1;
    sem_b.sem_flg=SEM_UNDO;//auto release
    semop(sem_id,&sem_b,1);
}


//main function
int main(int argc,char *agrv[])
{
    int i;
    int pause_time;
    char op_char='O';

    srand((unsigned int)getpid());
    sem_id=semget((key_t)1234,1,0666|IPC_CREAT);

    if(argc>1)
    {
        set_semvalue();
        op_char='X';
        sleep(2);
    }

    for(i=0;i<10;i++)
    {
        semaphore_p();
        printf("%c",op_char);
        fflush(stdout);
        pause_time=rand()%3;
        sleep(pause_time);
        printf("%c",op_char);
        fflush(stdout);

        semaphore_v();
        pause_time=rand()%2;
        sleep(pause_time);
    }

    printf("\n%d - finished\n",getpid());

    if(argc>1)
    {
        sleep(10);
        del_semvalue();
    }

    exit(0);
}

jiang@ubuntu:~/myTest./sem1 1 &  
[1] 12839  
jiang@ubuntu:~/myTest
./sem1
OOXXOOXXOOXXOOXXOOXXXXOOXXOOXXOOXXOOXXOO

12839 - finished
12840 - finished
jiang@ubuntu:~/myTest$

你可能感兴趣的:(linux,信号量,进程间通信)