8

我正在从 Unix 环境中的高级编程中尝试这个程序。

#include<stdio.h>
#include<signal.h>

static void handler(int sig){
    if(sig == SIGUSR1)
        printf("handled user1 signal");
    else if(sig == SIGUSR2)
        printf("handles user2 signal");
    else
        printf("unkown signal");
}

int main(){

    if(signal(SIGUSR1, handler) == SIG_ERR)
        printf("can't handle signal SIGUSR1");
    if(signal(SIGUSR2, handler) == SIG_ERR)
        printf("can't handle signal SIGUSR2");
    for(;;)
        pause();
    return 0;
}

我正在使用 Ubuntu 11.10。我用 gcc 编译程序,然后按照书中的说明运行 a.out。

$./a.out& [1]+ 1345

$杀死-USR1 1345

但是没有打印输出。该程序一直在后台运行,我必须杀死它。

我尝试过的其他事情:

  1. 尝试处理 SIGINT 以查看在后台运行的程序是否导致问题。还是没有输出。

  2. 下载了最新版本的 FreeBSD 并在上面尝试了相同的程序,但遇到了同样的问题。

  3. 我在设置信号处理程序之前放了一条 printf 语句:

    int main(){
        printf("printf is working...");
        //exit(0);
        if(signal(SIGUSR1, handler) == SIG_ERR)
        ...
    

当 exit() 被注释时,没有输出。当我取消注释时,将打印输出。

请告诉我我在这做错了什么?

PS:不建议使用 sigaction()。我正在学习 Unix 编程,而不是构建任何实际应用程序。

4

1 回答 1

15

的输出printf被缓冲。这意味着它存储在内存中,直到刷新到输出。刷新文本的最佳方法printf是用换行符结束文本。您也可以使用该fflush功能手动冲洗。

但是,您应该注意,在信号处理程序中使用类似printffflush不被认为是安全的输出函数。

于 2012-08-27T09:47:36.537 回答