如何在使用匿名 posix 信号量的进程中实现生产者/消费者问题?(这意味着我需要有 2 个进程依次打印一些文本,第 2 个可以从第 1 个分叉)
pthread_t pchild;
int i = 0;
pid_t pid;
sem_init(&fst, 1, 1);
sem_init(&scnd, 1, 0);
if((pid = fork()) == 0){
while(i<10){
sem_wait(&scnd);
printf("CHILD\n");
sem_post(&fst);
i++;
}
}else if(pid != -1){
while(i<10){
sem_wait(&fst);
printf("parent\n");
sem_post(&scnd);
i++;
}
}else{ printf("error - fork !!!\n");}
sem_destroy(&fst);
sem_destroy(&scnd);
此代码仅打印“父级”- 1 次,但我在 oracle 文档http://docs.oracle.com/cd/E19253-01/816-5137中发现“未命名的信号量是私有的,通过 fork() 继承” /sync-39/index.html 怎么了?
我的解决方案在这里https://www.dropbox.com/s/zzgsyj9rq1ngv0s/ost_13p.c