小编Ken*_*eth的帖子

SIGIO到达文件描述符我没有设置它,什么时候没有IO

我正在尝试在文件描述符上进行I/O时接收信号.程序在不执行I/O时需要执行其他操作,因此使用select(2)不是一个选项.

当我在下面运行示例代码时,它会尽可能快地从处理程序内部打印消息,即使stdin上没有数据也是如此.甚至更奇怪的是siginfo_t结构中报告的文件描述符因运行而异.我只为stdin(fd 0)设置了它; 为什么处理程序会报告任何其他值?有时我看到0,有时,我看到1,大多数时候我看到'?',表示除0,1或2之外的值.

这是在OpenSUSE 12.3,Linux内核3.7.10-1.16上,但我看到CentOS 6.4及其库存内核出现了同样的问题.

我在处理程序中使用write,因为signal(7)表示它是可重入的,因此在信号处理程序中使用是合法的.这也是为什么我不打印sinfo-> si_fd的值; snprintf不可重入.有一段时间我怀疑使用SIGIO的stdio库,这就是为什么示例程序中没有stdio调用的原因(除了可能在库函数err(3)中).

感谢您花时间阅读我的代码.

#include <fcntl.h>
#include <time.h>
#include <string.h>
#include <stdio.h>
#include <signal.h>
#include <unistd.h>
#include <stdlib.h>
#include <err.h>
#include <errno.h>

int needRead = 0;
const unsigned int bufsize = 256;

void handler(int sig, siginfo_t *sinfo, void *value)
{
    char *cp;

    cp = "in handler. fd: ";
    write(2, cp, strlen(cp));
    switch(sinfo->si_fd) {
        case 0: cp = "0\n"; break;
        case 1: cp = "1\n"; break;
        case 2: cp = "2\n"; break;
        default: cp …
Run Code Online (Sandbox Code Playgroud)

c linux signals

5
推荐指数
1
解决办法
5390
查看次数

标签 统计

c ×1

linux ×1

signals ×1