• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            旅途

            如果想飛得高,就該把地平線忘掉

            linux信號(hào)機(jī)制之sigaction結(jié)構(gòu)體淺析

            ???? 信號(hào)安裝函數(shù)sigaction(int signum,const struct sigaction *act,struct sigaction *oldact)的第二個(gè)參數(shù)是一個(gè)指向sigaction結(jié)構(gòu)的指針(結(jié)構(gòu)體名稱與函數(shù)名一樣,千萬(wàn)別弄混淆了)。在結(jié)構(gòu)sigaction的實(shí)例中, 指定了對(duì)特定信號(hào)的處理,信號(hào)所傳遞的信息,信號(hào)處理函數(shù)執(zhí)行過(guò)程中應(yīng)屏蔽掉哪些函數(shù)等。當(dāng)然,此指針也可以為NULL,進(jìn)程會(huì)以默認(rèn)方式處理信號(hào)。以下 就簡(jiǎn)單介紹一下sigaction結(jié)構(gòu)以及一般的用法。

            ??????? 對(duì)于內(nèi)核頭文件而言,struct sigaction 結(jié)構(gòu)體定義在kernel/include/asm/signal.h,此頭文件又被kernel/include/linux/signal.h包含。
            ??????? 對(duì)于用戶空間的頭文件而言,struct sigaction定義在 /usr/include/bits/sigaction.h,此頭文件又被/usr/include/signal.h包含,所以應(yīng)用程序中如果用到此 結(jié)構(gòu),只要#include <signal.h>即可。注意內(nèi)核中的定義和應(yīng)用程序中的定義是不一樣的,內(nèi)核空間的sigaction結(jié)構(gòu)只支持函數(shù)類型為 __sighandler_t的信號(hào)處理函數(shù),不能處理信號(hào)傳遞的額外信息。具體定義如下:

            ……
            /* 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的原型是一個(gè)參數(shù)為int,返回類型為void的函數(shù)指針。參數(shù)即為信號(hào)值,所以信號(hào)不能傳遞除信號(hào)值之外的任何信息;

            sa_sigaction的原型是一個(gè)帶三個(gè)參數(shù),類型分別為int,struct siginfo *,void *,返回類型為void的函數(shù)指針。第一個(gè)參數(shù)為信號(hào)值;第二個(gè)參數(shù)是一個(gè)指向struct siginfo結(jié)構(gòu)的指針,此結(jié)構(gòu)中包含信號(hào)攜帶的數(shù)據(jù)值;第三個(gè)參數(shù)沒(méi)有使用。

            sa_mask指定在信號(hào)處理程序執(zhí)行過(guò)程中,哪些信號(hào)應(yīng)當(dāng)被阻塞。默認(rèn)當(dāng)前信號(hào)本身被阻塞。

            sa_flags包含了許多標(biāo)志位,比較重要的一個(gè)是SA_SIGINFO,當(dāng)設(shè)定了該標(biāo)志位時(shí),表示信號(hào)附帶的參數(shù)可以傳遞到信號(hào)處理函數(shù)中。即 使sa_sigaction指定信號(hào)處理函數(shù),如果不設(shè)置SA_SIGINFO,信號(hào)處理函數(shù)同樣不能得到信號(hào)傳遞過(guò)來(lái)的數(shù)據(jù),在信號(hào)處理函數(shù)中對(duì)這些信 息的訪問(wèn)都將導(dǎo)致段錯(cuò)誤。

            sa_restorer已過(guò)時(shí),POSIX不支持它,不應(yīng)再使用。

            ??????? 因此,當(dāng)你的信號(hào)需要接收附加信息的時(shí)候,你必須給sa_sigaction賦信號(hào)處理函數(shù)指針,同時(shí)還要給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;
            ??
            ?????????????? ……
            ???? }
            ??????? 如果你的應(yīng)用程序只需要接收信號(hào),而不需要接收額外信息,那你需要的設(shè)置的是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;
            ??
            ?????????????? ……
            ????? }

            ????? 如果需要更詳細(xì)說(shuō)明,請(qǐng)參閱sigaction的man手冊(cè)。

            posted on 2007-08-02 00:34 旅途 閱讀(2165) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Linux開(kāi)發(fā)

            久久一日本道色综合久久| 青青久久精品国产免费看| 97久久精品人妻人人搡人人玩| 久久91精品综合国产首页| 久久久噜噜噜久久熟女AA片| 国产精品成人精品久久久| 亚洲AV无码久久精品蜜桃| 国产精品中文久久久久久久| 久久亚洲av无码精品浪潮| 久久男人中文字幕资源站| 国产亚州精品女人久久久久久 | 久久这里有精品视频| 国产精品丝袜久久久久久不卡| 日本一区精品久久久久影院| 国产日产久久高清欧美一区| 久久99热国产这有精品| 久久亚洲精品中文字幕三区| 91精品国产91热久久久久福利| 久久九九有精品国产23百花影院| 久久线看观看精品香蕉国产| 中文字幕久久欲求不满| 青春久久| 久久国产精品成人片免费| 精品久久久久久中文字幕| 国产成人久久精品麻豆一区| 无码国内精品久久人妻麻豆按摩| 少妇无套内谢久久久久| 色偷偷久久一区二区三区| 久久香蕉国产线看观看乱码| 亚洲欧美日韩久久精品| 少妇久久久久久久久久| 91精品无码久久久久久五月天| 开心久久婷婷综合中文字幕| 久久精品国产精品亚洲精品 | 久久国产午夜精品一区二区三区| 国内精品久久久久久久涩爱 | 久久国产精品免费| 日韩欧美亚洲综合久久| 精品久久久久久国产| 青青青青久久精品国产h久久精品五福影院1421 | 日韩中文久久|