假设两个进程(父子进程)对一个文件进行写操作,但是这个文件同一时间只能有一个进程进行写操作。 //利用信号量实现pv操作 #include <stdio.h> #include <stdlib.h> #include <sys/ipc.h> #include <sys/sem.h> #include <sys/types.h> #include <fcntl.h> struct sembuf sops; static int sid; //创建一个新的信号量集 int createSemset(void) { char* pathname="semset"; if( access(pathname, F_OK)!=0 ) { int fd=open(pathname, O_RDWR | O_CREAT, 0666); if( fd<0 ) { perror("open"); return -1; } } key_t key=ftok(pathname, 'a'); if( -1==key ) { perror("ftok"); return -1; } return semget(key, 1, IPC_CREAT | 0666) ; } //P操作 int P(void) { sops.sem_num=0; sops.sem_op=-1; sops.sem_flg=0; return semop(sid, &sops, 1); } //V操作 int V(void) { sops.sem_num=0; sops.sem_op=1; sops.sem_flg=0; return semop(sid, &sops, 1); } int main(int argc, char *argv[]) { sid=createSemset(); if( -1==sid ) { perror("createSemset"); exit(1); } if( -1==semctl(sid, 0, SETVAL, 1) ) { perror("SETVAL"); exit(1); } pid_t pid=fork(); if( pid<0 ) { perror("fork"); exit(1); } else if( 0==pid ) { while(1) { if( -1==P() ) { printf("P操作失败!/n"); exit(1); } printf("子进程正在对文件进行写操作!/n"); sleep(1); printf("子进程写操作完毕,释放资源!/n"); if( -1==V() ) { printf("V操作失败!"); exit(1); } } } else { while(1) { if( -1==P() ) { printf("P操作失败!/n"); exit(1); } printf("父进程进程正在对文件进行写操作!/n"); sleep(1); printf("父进程写操作完毕,释放资源!/n"); if( -1==V() ) { printf("V操作失败!"); exit(1); } } } //删除信号量集 //semctl(sid, 0, IPC_RMID); }