4

我有一个用 C 语言为 Linux 平台编写的第 3 方应用程序。该应用程序使用以下代码创建信号量:

union semun {
    int Value;
    struct semid_ds *Buffer;
    unsigned short * Array;
} Arg;

Arg.Value = 0;

SemId = semget(IPC_PRIVATE , ONE_SEMAPHORE, 0666 | IPC_CREAT);

semctl(SemId, 0, SETVAL, Arg);

当应用程序退出时,应用程序使用以下代码删除这些信号量:

semctl(SemId, 0, IPC_RMID);

如果应用程序异常停止(例如通过发送多个 SIGINT 信号),这些信号量将保持打开状态。可以使用以下命令打开这些信号量:

ipcs -s

必须使用 ipcrm 命令手动从系统中删除这些信号量。

当应用程序最终退出时,如何确保删除应用程序创建的信号量?我已经读过 exit() 调用关闭了所有打开的命名信号量。然而,这些不是命名的信号量。

我提前感谢您的帮助。

4

2 回答 2

4

[这在程序异常终止的情况下无济于事]

您可能希望使用 .注册应用程序定义的退出处理程序atexit()

void myexit(void)
{
  semctl(SemId, 0, IPC_RMID);
}

...

int main()
{
  atexit(myexit); /* register exit handler */
  ...

有关详细信息,atexit()请参阅man atexit

于 2012-07-02T17:30:19.067 回答
4

为了处理异常终止,我们可以安装信号处理程序

/* signal handlers available in signal.h */
#include <signal.h>

void SignalHandler(int iSignalNum)
{
    switch(iSignalNum)
    {
    case SIGINT:
    case SIGSEGV:
    case SIGTSTP:
        {
           /* Add Stuffs if necessary */
           semctl(SemId, 0, IPC_RMID);
        }
     break;
     default:
        break;
    }
   exit(0); 
}        


int main()
{
        ....

        /* Register the signal handlers */
        signal(SIGINT,  SignalHandler);
        signal(SIGSEGV, SignalHandler);
        signal(SIGTSTP, SignalHandler);
        .....
}
于 2012-07-12T07:20:21.577 回答