我有一个派生了一些子进程的进程。它们都共享一个信号量。
在我的主程序中。
sem_t *sharedSem = sem_open(SHAREDSEM, O_CREAT, 0600, 4); // Initial 1在我的孩子程序里。
> sem_t * serverSem = sem_open(SHAREDSEM, 0);
sem_wait(serverSem);
printf("PRINTING\n");
sem_post(sharedSem);据我观察,问题出在sem_wait内部。对子进程执行sem_wait之前发生的任何事情都可以正常打印出来。但是,sem_wait之后的printf()永远不会打印。一次也没有。
我已经做了几个小时了,我看不出我有什么问题。有人能帮上忙吗?谢谢。
发布于 2015-06-21 04:04:13
我认为这种行为是由前几次运行中缺少sem_close()引起的。只需确保您正确地关闭了信号量,以便在将来的运行中正确地分配信号量的起始值,并且sem_wait()应该可以工作。
https://stackoverflow.com/questions/15046492
复制相似问题