- 浏览: 584099 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (365)
- Tomcat调优 (2)
- Apache Http (20)
- Webserver安装 (5)
- Linux安装 (28)
- Linux常用命令 (17)
- C语言及网络编程 (10)
- 文件系统 (0)
- Lucene (12)
- Hadoop (9)
- FastDFS (8)
- 报表 (0)
- 性能测试 (1)
- JAVA (18)
- CSharp (3)
- C++ (38)
- BI (0)
- 数据挖掘 (0)
- 数据采集 (0)
- 网址收集整理 (3)
- Resin (0)
- JBoss (0)
- nginx (0)
- 数据结构 (1)
- 随记 (5)
- Katta (1)
- Shell (6)
- webservice (0)
- JBPM (2)
- JQuery (6)
- Flex (41)
- SSH (0)
- javascript (7)
- php (13)
- 数据库 (6)
- 搜索引擎排序 (2)
- LVS (3)
- solr (2)
- windows (1)
- mysql (3)
- 营销软件 (1)
- tfs (1)
- memcache (5)
- 分布式搜索 (3)
- 关注的博客 (1)
- Android (2)
- clucene (11)
- 综合 (1)
- c c++ 多线程 (6)
- Linux (1)
- 注册码 (1)
- 文件类型转换 (3)
- Linux 与 asp.net (2)
- perl (5)
- coreseek (1)
- 阅读器 (2)
- SEO (1)
- 励志 (1)
- 在线性能测试工具 (1)
- yii (7)
- 服务器监控 (1)
- 广告 (1)
- 代理服务 (5)
- zookeeper (8)
- 广告联盟 (0)
- 常用软件下载 (1)
- 架设自已的站点心得 (0)
最新评论
-
terry07:
java 7 用这个就可以了 Desktop desktop ...
关于java Runtime.getRunTime.exec(String command)的使用 -
HSINKING:
怎么设置打开的dos 窗口是指定的路径下
关于java调用bat文件,不打开窗口 -
liubang201010:
hyperic hq更多参考资料,请访问:http://www ...
hyperic-hq -
^=^:
STDIN_FILENO是unistd.h中定义的一个numb ...
深入理解dup和dup2的用法 -
antor:
留个记号,学习了
[转]用java流方式判断文件类型
linux 2009-02-20 16:47:00 阅读460 评论0 字号:大中小 订阅
转http://hi.baidu.com/phenix_yw/blog/item/6eb4ca391d1479f23a87ce19.html
信号安装函数sigaction(int signum,const struct sigaction *act,struct sigaction *oldact)的第二个参数是一个指向sigaction结构的指针(结构体名称与函数名一样,千万别弄混淆了)。在结构sigaction的实例中,指定了对特定信号的处理,信号所传递的信息,信号处理函数执行过程中应屏蔽掉哪些函数等。当然,此指针也可以为NULL,进程会以默认方式处理信号。以下就简单介绍一下sigaction结构以及一般的用法。
对于内核头文件而言,struct sigaction 结构体定义在kernel/include/asm/signal.h,此头文件又被kernel/include/linux/signal.h包含。
对于用户空间的头文件而言,struct sigaction定义在 /usr/include/bits/sigaction.h,此头文件又被/usr/include/signal.h包含,所以应用程序中如果用到此结构,只要#include <signal.h>即可。注意内核中的定义和应用程序中的定义是不一样的,内核空间的sigaction结构只支持函数类型为__sighandler_t的信号处理函数,不能处理信号传递的额外信息。具体定义如下:
……
/* Type of a signal handler. */
typedef void (*__sighandler_t)(int);
……
#ifdef __KERNEL__
struct old_sigaction {
__sighandler_t sa_handler;
old_sigset_t sa_mask;
unsigned long sa_flags;
void (*sa_restorer)(void);
};
struct sigaction {
__sighandler_t sa_handler;
unsigned long sa_flags;
void (*sa_restorer)(void);
sigset_t sa_mask; /* mask last for extensibility */
};
struct k_sigaction {
struct sigaction sa;
};
#else
/* Here we must cater to libcs that poke about in kernel headers. */
struct sigaction {
union {
__sighandler_t _sa_handler;
void (*_sa_sigaction)(int, struct siginfo *, void *);
} _u;
sigset_t sa_mask;
unsigned long sa_flags;
void (*sa_restorer)(void);
};
#define sa_handler _u._sa_handler
#define sa_sigaction _u._sa_sigaction
#endif /* __KERNEL__ */
sa_handler的原型是一个参数为int,返回类型为void的函数指针。参数即为信号值,所以信号不能传递除信号值之外的任何信息;
sa_sigaction的原型是一个带三个参数,类型分别为int,struct siginfo *,void *,返回类型为void的函数指针。第一个参数为信号值;第二个参数是一个指向struct siginfo结构的指针,此结构中包含信号携带的数据值;第三个参数没有使用。
sa_mask指定在信号处理程序执行过程中,哪些信号应当被阻塞。默认当前信号本身被阻塞。
sa_flags包含了许多标志位,比较重要的一个是SA_SIGINFO,当设定了该标志位时,表示信号附带的参数可以传递到信号处理函数中。即使sa_sigaction指定信号处理函数,如果不设置SA_SIGINFO,信号处理函数同样不能得到信号传递过来的数据,在信号处理函数中对这些信息的访问都将导致段错误。
sa_restorer已过时,POSIX不支持它,不应再使用。
因此,当你的信号需要接收附加信息的时候,你必须给sa_sigaction赋信号处理函数指针,同时还要给sa_flags赋SA_SIGINFO,类似下面的代码:
#include <signal.h>
……
void sig_handler_with_arg(int sig,siginfo_t *sig_info,void *unused){……}
int main(int argc,char **argv)
{
struct sigaction sig_act;
……
sigemptyset(&sig_act.sa_mask);
sig_act.sa_sigaction=sig_handler_with_arg;
sig_act.sa_flags=SA_SIGINFO;
……
}
如果你的应用程序只需要接收信号,而不需要接收额外信息,那你需要的设置的是sa_handler,而不是sa_sigaction,你的程序可能类似下面的代码:
#include <signal.h>
……
void sig_handler(int sig){……}
int main(int argc,char **argv)
{
struct sigaction sig_act;
……
sigemptyset(&sig_act.sa_mask);
sig_act.sa_handler=sig_handler;
sig_act.sa_flags=0;
……
}
如果需要更详细说明,请参阅sigaction的man手册。
转http://hi.baidu.com/phenix_yw/blog/item/6eb4ca391d1479f23a87ce19.html
信号安装函数sigaction(int signum,const struct sigaction *act,struct sigaction *oldact)的第二个参数是一个指向sigaction结构的指针(结构体名称与函数名一样,千万别弄混淆了)。在结构sigaction的实例中,指定了对特定信号的处理,信号所传递的信息,信号处理函数执行过程中应屏蔽掉哪些函数等。当然,此指针也可以为NULL,进程会以默认方式处理信号。以下就简单介绍一下sigaction结构以及一般的用法。
对于内核头文件而言,struct sigaction 结构体定义在kernel/include/asm/signal.h,此头文件又被kernel/include/linux/signal.h包含。
对于用户空间的头文件而言,struct sigaction定义在 /usr/include/bits/sigaction.h,此头文件又被/usr/include/signal.h包含,所以应用程序中如果用到此结构,只要#include <signal.h>即可。注意内核中的定义和应用程序中的定义是不一样的,内核空间的sigaction结构只支持函数类型为__sighandler_t的信号处理函数,不能处理信号传递的额外信息。具体定义如下:
……
/* Type of a signal handler. */
typedef void (*__sighandler_t)(int);
……
#ifdef __KERNEL__
struct old_sigaction {
__sighandler_t sa_handler;
old_sigset_t sa_mask;
unsigned long sa_flags;
void (*sa_restorer)(void);
};
struct sigaction {
__sighandler_t sa_handler;
unsigned long sa_flags;
void (*sa_restorer)(void);
sigset_t sa_mask; /* mask last for extensibility */
};
struct k_sigaction {
struct sigaction sa;
};
#else
/* Here we must cater to libcs that poke about in kernel headers. */
struct sigaction {
union {
__sighandler_t _sa_handler;
void (*_sa_sigaction)(int, struct siginfo *, void *);
} _u;
sigset_t sa_mask;
unsigned long sa_flags;
void (*sa_restorer)(void);
};
#define sa_handler _u._sa_handler
#define sa_sigaction _u._sa_sigaction
#endif /* __KERNEL__ */
sa_handler的原型是一个参数为int,返回类型为void的函数指针。参数即为信号值,所以信号不能传递除信号值之外的任何信息;
sa_sigaction的原型是一个带三个参数,类型分别为int,struct siginfo *,void *,返回类型为void的函数指针。第一个参数为信号值;第二个参数是一个指向struct siginfo结构的指针,此结构中包含信号携带的数据值;第三个参数没有使用。
sa_mask指定在信号处理程序执行过程中,哪些信号应当被阻塞。默认当前信号本身被阻塞。
sa_flags包含了许多标志位,比较重要的一个是SA_SIGINFO,当设定了该标志位时,表示信号附带的参数可以传递到信号处理函数中。即使sa_sigaction指定信号处理函数,如果不设置SA_SIGINFO,信号处理函数同样不能得到信号传递过来的数据,在信号处理函数中对这些信息的访问都将导致段错误。
sa_restorer已过时,POSIX不支持它,不应再使用。
因此,当你的信号需要接收附加信息的时候,你必须给sa_sigaction赋信号处理函数指针,同时还要给sa_flags赋SA_SIGINFO,类似下面的代码:
#include <signal.h>
……
void sig_handler_with_arg(int sig,siginfo_t *sig_info,void *unused){……}
int main(int argc,char **argv)
{
struct sigaction sig_act;
……
sigemptyset(&sig_act.sa_mask);
sig_act.sa_sigaction=sig_handler_with_arg;
sig_act.sa_flags=SA_SIGINFO;
……
}
如果你的应用程序只需要接收信号,而不需要接收额外信息,那你需要的设置的是sa_handler,而不是sa_sigaction,你的程序可能类似下面的代码:
#include <signal.h>
……
void sig_handler(int sig){……}
int main(int argc,char **argv)
{
struct sigaction sig_act;
……
sigemptyset(&sig_act.sa_mask);
sig_act.sa_handler=sig_handler;
sig_act.sa_flags=0;
……
}
如果需要更详细说明,请参阅sigaction的man手册。
发表评论
-
[转载]strftime() 函数_时间格式
2011-01-12 11:21 1191[转载]strftime() 函数 (2007-12-06 1 ... -
fork函数
2011-01-11 13:23 916引用 在linux中,只有一 ... -
如何调试守护进程
2011-01-11 13:05 3213如何调试守护进程 我写 ... -
UNIX管道编程——使用pipe函数,dup函数,dup2函数
2011-01-11 10:02 51772009-12-29 11:46管道在unix ... -
c中的管道及复制描述符
2011-01-10 17:22 12391、 #include <stdio.h& ... -
如何在运行时确定对象类型(RTTI)
2011-01-10 11:45 943引用作者:NorthTibet RTTI 是“R ... -
string, char*, int类型转换 , c++强制转化
2011-01-10 10:04 16504一、 以下是常用的几种类型互相之间的转换 string 转 ... -
Linux下的管道编程技术-dup函数和dup2函数
2011-01-09 23:45 1150from [url]http://www.xxlinux.co ... -
Linux下使用C/C++访问数据库
2011-01-07 16:19 1342Linux下使用C/C++访问数据库——MySQL篇 ... -
多核分布式队列的实现:“偷”与“自私”的运用
2011-01-06 11:38 1062原创作品,允许转载, ... -
Boost和STL学习资料大全
2011-01-06 09:38 2639from http://blog.csdn.net/k2eat ... -
linux平台上编译安装boost库
2011-01-06 09:33 6739from http://dev.firnow.com/co ... -
C++多线程入门
2010-12-30 09:52 1249第1节 背景 为了更好 ... -
c++中__declspec用法总结
2010-12-29 17:47 1787c++中__declspec用法总结C++ ... -
__cplusplus的用处
2010-12-29 14:07 1063作者: Aprilgogo 发表日期: 2007-03-1 ... -
#ifdef __cplusplus深度剖析
2010-12-29 14:06 826时常在cpp的代码之中看 ... -
C和C++之间库的互相调用
2010-12-29 13:44 1056C和C++之间库的互相调用 昨晚有个朋友问我关于在C中调用C ... -
c, c++ 库调用相关知识
2010-12-29 13:41 13811。 重载是如何实现的 ... -
放在函数后面的const是什么意思?
2010-12-17 16:13 1458经常看到这样的定义: void f() const ... -
临时记录
2010-12-15 15:37 8101\ c开发包典型的名字是 glibc-devel-somet ...
相关推荐
在计算机编程中,尤其是在Linux环境下,信号(Signal)作为一种重要的通信机制被广泛应用于进程间通信。为了更好地控制信号的行为,POSIX标准引入了`sigaction`函数,该函数允许程序员以更灵活的方式管理信号的处理...
本篇文章将深入探讨Linux信号机制,包括其基本概念、主要函数如`signal`和`sigaction`的使用方法,以及相关实例。 首先,信号是内核向进程传递信息的一种机制,它可以用来中断进程的正常执行,或者通知进程发生了...
Linux信号机制是操作系统内核中用于进程间通信和异常处理的一种机制。它允许一个进程向另一个进程发送消息,这些消息可以是关于特定事件的通知,或者是请求执行特定操作的命令。在Linux系统中,信号机制是基于POSIX...
下面我们将深入探讨Linux信号机制的各个方面。 1. **信号定义与类型**:Linux系统定义了一系列预定义的信号,如SIGINT(中断,由Ctrl+C产生)、SIGTERM(正常终止请求)、SIGKILL(强制终止,无法被捕获或忽略)...
Linux 信号机制是操作系统提供的一种进程间通信方式,它用于通知进程发生了特定的异步事件。信号机制在Linux编程中扮演着重要角色,因为它允许进程响应来自其他进程、内核或者用户的事件。以下是对信号机制的详细...
信号是Linux中进程间传递控制消息的一种机制,类似于硬件中断。信号可以用于通知进程执行特定的操作,如终止进程、暂停进程或执行特定的用户定义行为。常见的信号类型包括进程终止信号、定时器信号以及用户自定义...
在Linux操作系统中,信号(Signal)是一种异步通信机制,用于通知进程发生了某种事件或条件。信号机制使得进程能够响应外部...理解并熟练掌握信号机制,可以帮助开发者更好地设计和实现高效率、高可靠的Linux应用程序。
Linux信号机制允许进程通过发送和接收信号来相互通信。在Linux系统中,信号的传递是通过内核来实现的,内核维护一个信号表来记录进程所接收到的信号。每个信号都有一个唯一的数字标识符和名称,如SIGINT(中断信号)...
### Linux信号机制详解 #### 一、信号及信号来源 信号是Linux系统中一种重要的进程间通信机制,它主要用于在程序或系统发生特定事件时通知进程。信号可以在多个层面上帮助开发者实现进程间的异步通信。 **信号的...
在Linux编程中,理解并掌握信号机制是非常关键的。本文将深入探讨信号的基本概念、处理方法、信号类型以及相关系统调用。 1. **信号的基本概念** 信号是一种轻量级的通知机制,用来告知进程发生了特定的异步事件。...
理解并熟练掌握Linux信号机制对于进行系统级编程至关重要。 信号是操作系统向进程发送的一种消息,它可能由内核生成,也可能由另一个进程产生。当进程接收到一个信号时,它可以选择忽略该信号,或者按照预设的行为...
本文将深入探讨Linux下的信号机制,以及相关的函数。 首先,我们需要理解信号的基本概念。信号是异步通知,可以中断进程的执行流程,用于处理异常、结束进程、请求资源或通知事件。Linux系统定义了一套标准信号,如...
在信号处理过程中,如果信号到来时进程正在执行某个低速系统调用,系统会如何处理这个问题是设计信号机制时需要考虑的问题。Linux内核通常的做法是,在信号处理器执行完毕后,会重新尝试该被中断的系统调用,这种...
### Linux信号专题笔记 #### Linux信号基本概念 ...通过以上介绍,我们可以了解到Linux信号机制的基本原理及其在系统中的作用。信号是Linux系统中一个重要的机制,理解和掌握它可以更好地管理和控制进程的行为。
Linux系统编程中的信号机制是操作系统提供的一种异步通信方式,它允许进程间或者操作系统与进程之间传递简短的通知。信号的概念源于现实生活中的一些信号行为,它们具有意图简单、信息量小且满足特定触发条件的特点...