概述
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc,char * argv[]){
fork();
int i=0;
for(;i<5;i++){
printf("PID:%d,enter\n",getpid());
sleep(1);// do something
printf("PID:%d,do something\n",getpid());
printf("PID:%d,leave\n",getpid());
}
}
上述代码由于并发执行和抢占资源,导致两个进程执行顺序的不确定性,会出现执行的不规律性
分类:
根据共享资源的数目可分为二值信号量和计数信号量两类。
分类 | 取值 |
---|---|
二值信号量 | 0和1 |
计数信号量 | 0和n |
作用:
控制多进程共享资源的访问(资源有限并且不共享)
本质:
任一时刻只能有一个进程访问临界区(代码),数据更新的代码。
基本操作:PV
原子操作操作也被成为PV原语(P来源于Dutchproberen"测试",V来源于Dutchverhogen"增加")
信号:
分类 | 取值 |
---|---|
P(信号量) | 0:挂起进程;>0:减1 |
V(信号量) | 0:恢复进程;>0:加1 |
信号量
查看:
man sem_overview
1.1 接口
头文件:semaphore.h
库:pthread
分类:
信号量分为命名信号量(基于文件)与匿名信号量(基于内存)两种。
1.2 函数
1.2.1 命名信号量/基于文件
操作 | 含义 |
---|---|
创建 | sem_t *sem_open(const char *name, int oflag, mode_t mode,unsigned int value) |
删除 | int sem_unlink(const char *name) |
打开 | sem_t *sem_open(const char *name, int oflag) |
关闭 | int sem_close(sem_t *sem) |
挂出 | int sem_post(sem_t *sem) |
等待 | int sem_wait(sem_t *sem) |
尝试等待 | int sem_trywait(sem_t *sem) |
获取信号量的值 | int sem_getvalue(sem_t *sem, int *sval) |