Linux 進程學習(四)------ sigaction 函數

轉自:http://www.cnblogs.com/wblyuyang/archive/2012/11/13/2768923.html

使用 sigaction 函數:
?signal 函數的使用方法簡單,但并不屬于 POSIX 標準,在各類 UNIX 平臺上的實現不盡相同,因此其用途受

到了一定的限制。而 POSIX 標準定義的信號處理接口是 sigaction 函數,其接口頭文件及原型如下:
?#include <signal.h>
?int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);

?◆ signum:要操作的信號。
?◆ act:要設置的對信號的新處理方式。
?◆ oldact:原來對信號的處理方式。
?◆ 返回值:0 表示成功,-1 表示有錯誤發生。

?struct sigaction 類型用來描述對信號的處理,定義如下:
?struct sigaction
?{
??void???? (*sa_handler)(int);
??void???? (*sa_sigaction)(int, siginfo_t *, void *);
??sigset_t? sa_mask;
??int?????? sa_flags;
??void???? (*sa_restorer)(void);
?};

?在這個結構體中,成員 sa_handler 是一個函數指針,其含義與 signal 函數中的信號處理函數類似。成員

sa_sigaction 則是另一個信號處理函數,它有三個參數,可以獲得關于信號的更詳細的信息。當 sa_flags 成員的值

包含了 SA_SIGINFO 標志時,系統將使用 sa_sigaction 函數作為信號處理函數,否則使用 sa_handler 作為信號處理

函數。在某些系統中,成員 sa_handler 與 sa_sigaction 被放在聯合體中,因此使用時不要同時設置。
?sa_mask 成員用來指定在信號處理函數執行期間需要被屏蔽的信號,特別是當某個信號被處理時,它自身會被

自動放入進程的信號掩碼,因此在信號處理函數執行期間這個信號不會再度發生。
?sa_flags 成員用于指定信號處理的行為,它可以是一下值的“按位或”組合。
?
?◆ SA_RESTART:使被信號打斷的系統調用自動重新發起。
?◆ SA_NOCLDSTOP:使父進程在它的子進程暫停或繼續運行時不會收到 SIGCHLD 信號。
?◆ SA_NOCLDWAIT:使父進程在它的子進程退出時不會收到 SIGCHLD 信號,這時子進程如果退出也不會成為僵

尸進程。
?◆ SA_NODEFER:使對信號的屏蔽無效,即在信號處理函數執行期間仍能發出這個信號。
?◆ SA_RESETHAND:信號處理之后重新設置為默認的處理方式。
?◆ SA_SIGINFO:使用 sa_sigaction 成員而不是 sa_handler 作為信號處理函數。

?re_restorer 成員則是一個已經廢棄的數據域,不要使用。

?下面用一個例程來說明 sigaction 函數的使用,代碼如下:

復制代碼
 1 #include <stdio.h>
 2 #include <unistd.h>
 3 #include <signal.h>
 4 #include <errno.h>
 5 
 6 static void sig_usr(int signum)
 7 {
 8     if(signum == SIGUSR1)
 9     {
10         printf("SIGUSR1 received\n");
11     }
12     else if(signum == SIGUSR2)
13     {
14         printf("SIGUSR2 received\n");
15     }
16     else
17     {
18         printf("signal %d received\n", signum);
19     }
20 }
21 
22 int main(void)
23 {
24     char buf[512];
25     int  n;
26     struct sigaction sa_usr;
27     sa_usr.sa_flags = 0;
28     sa_usr.sa_handler = sig_usr;   //信號處理函數
29     
30     sigaction(SIGUSR1, &sa_usr, NULL);
31     sigaction(SIGUSR2, &sa_usr, NULL);
32     
33     printf("My PID is %d\n", getpid());
34     
35     while(1)
36     {
37         if((n = read(STDIN_FILENO, buf, 511)) == -1)
38         {
39             if(errno == EINTR)
40             {
41                 printf("read is interrupted by signal\n");
42             }
43         }
44         else
45         {
46             buf[n] = '\0';
47             printf("%d bytes read: %s\n", n, buf);
48         }
49     }
50     
51     return 0;
52 }
復制代碼

?在這個例程中使用 sigaction 函數為 SIGUSR1 和 SIGUSR2 信號注冊了處理函數,然后從標準輸入讀入字符

。程序運行后首先輸出自己的 PID,如:
?My PID is 5904
?
?這時如果從另外一個終端向進程發送 SIGUSR1 或 SIGUSR2 信號,用類似如下的命令:
?kill -USR1 5904

?則程序將繼續輸出如下內容:
?SIGUSR1 received
?read is interrupted by signal
?
?這說明用 sigaction 注冊信號處理函數時,不會自動重新發起被信號打斷的系統調用。如果需要自動重新發

起,則要設置 SA_RESTART 標志,比如在上述例程中可以進行類似一下的設置:
?sa_usr.sa_flags = SA_RESTART;


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/384395.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/384395.shtml
英文地址,請注明出處:http://en.pswp.cn/news/384395.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

linux網絡編程(二)高并發服務器

linux網絡編程&#xff08;二&#xff09;高并發服務器錯誤處理高并發服務器多進程并發服務器客戶端錯誤處理 #include "wrap.h"int Bind(int fd, const struct sockaddr* sa, socklen_t salen) {int ret;if ((ret bind(fd, sa, salen)) < 0){perror("bind…

linux知識(一) 程序、進程與線程

linux知識&#xff08;一&#xff09; 程序、進程與線程程序進程程序如何變成進程&#xff1f;線程線程與進程fork和創建新線程的區別優點程序 程序&#xff1a;程序是已編譯好的二進制文件&#xff0c;存儲在磁盤中&#xff0c;不占用系統資源 程序包括&#xff1a; RO段&am…

linux 信號signal和sigaction理解

轉載&#xff1a;http://blog.csdn.net/beginning1126/article/details/8680757 今天看到unp時發現之前對signal到理解實在淺顯&#xff0c;今天拿來單獨學習討論下。 signal&#xff0c;此函數相對簡單一些&#xff0c;給定一個信號&#xff0c;給出信號處理函數則可&#xff…

linux知識(二)互斥量、信號量和生產者消費者模型

linux知識&#xff08;二&#xff09;互斥量、信號量和生產者消費者模型一、互斥量產生原因二、信號量生產者消費者模型一、互斥量 產生原因 使用多線程常常會碰到數據混亂的問題&#xff0c;那么使用互斥量&#xff0c;相當于“加鎖”的操作&#xff0c;將有助于解決數據混亂…

基于Linux的Socket編程之TCP全雙工Server-Client聊天程序

轉載&#xff1a;http://blog.csdn.net/apollon_krj/article/details/53437764#0-tsina-1-58570-397232819ff9a47a7b7e80a40613cfe1 一、引言&#xff1a; 由于accept函數、read、write、recv、send等函數都是是阻塞式的&#xff0c;在同一個進程之中&#xff0c;只要有任何一個…

數據結構(一)線性表

數據結構&#xff08;一&#xff09;線性表一、線性表定義二、順序表定義動態數組三、單鏈表定義不帶頭結點帶頭結點頭結點與不帶頭結點的區別頭插法與尾插法雙鏈表循環鏈表循環單鏈表循環雙鏈表靜態鏈表一、線性表定義 線性表是具有相同數據類型的n個數據元素的有限序列 特點…

linux網絡編程(二)TCP通訊狀態

linux網絡編程&#xff08;二&#xff09;TCP通訊狀態TCP狀態轉換為什么需要等待2MSL&#xff1f;端口復用TCP狀態轉換 tcp協議連接開始會經過三次握手&#xff0c;客戶端和服務器開始都會處于CLOSED狀態 第一次握手&#xff1a;客戶端會先發送SYN請求給服務器&#xff0c;客戶…

gethostbyname() 函數說明

轉載&#xff1a;http://www.cnblogs.com/cxz2009/archive/2010/11/19/1881611.html gethostbyname()函數說明——用域名或主機名獲取IP地址 包含頭文件 #include <netdb.h> #include <sys/socket.h> 函數原型 struct hostent *gethostbyna…

linux網絡編程(三)select、poll和epoll

linux網絡編程&#xff08;三&#xff09;select、poll和epoll一、為什么會有多路I/O轉接服務器&#xff1f;二、select三、poll三、epoll一、為什么會有多路I/O轉接服務器&#xff1f; 為什么會有多路I/O轉接服務器呢&#xff1f;在學這個之前&#xff0c;我們同使用的是多線…

Linux socket編程(一) 對套接字操作的封裝

轉載:http://www.cnblogs.com/-Lei/archive/2012/09/04/2670942.html 以前寫的&#xff0c;現在回顧一下&#xff1a; 下面是對socket操作的封裝&#xff0c;因為在Linux下寫中文到了windows里面會亂碼&#xff0c;所以注釋用英文來寫&#xff0c;有空再查下解決方法吧 socket.…

數據結構(二)棧

棧一、棧順序棧線性棧(不帶頭結點)線性棧(帶頭結點)共享棧一、棧 棧是只允許在一端進行插入或刪除操作的線性表。 棧頂&#xff1a;線性表允許進行插入刪除的那一端 棧底&#xff1a;固定的&#xff0c;不允許進行插入和刪除的那一端 空棧&#xff1a;不含如何元素的空表 順序…

如何在linux上安裝sqlite數據庫

如何在linux上安裝sqlite數據庫一、下載二、解壓三、配置&#xff08;configure&#xff09;四、編譯和安裝五、執行sqlite3程序六、測試代碼一、下載 首先要先下載sqlite3源碼包 鏈接&#xff1a;https://pan.baidu.com/s/1_70342ZLlPjLlqGzpy5IHw 提取碼&#xff1a;84ne …

數據結構(三)隊列

數據結構&#xff08;三&#xff09;隊列隊列隊列&#xff08;順序存儲&#xff09;循環隊列&#xff08;順序存儲&#xff09;隊列&#xff08;鏈式存儲&#xff09;隊列 隊列是一種受限制的線性表&#xff0c;只允許表的一端插入&#xff0c;在表的另一端刪除 隊列&#xf…

Linux fcntl函數詳解

轉載&#xff1a;http://www.cnblogs.com/xuyh/p/3273082.html 功能描述&#xff1a;根據文件描述詞來操作文件的特性。 文件控制函數 fcntl -- file control 頭文件&#xff1a; #include <unistd.h> #include <fcntl.h> 函數原型&#xff1a; …

vs2019使用sqlite數據庫遠程連接linux

vs2019使用sqlite數據庫遠程連接linux一、sqlite3添加到目錄二、添加依賴庫三、測試一、sqlite3添加到目錄 將兩個sqlite3頭文件放入目錄中 二、添加依賴庫 打開項目屬性 添加完成 三、測試 #include <stdio.h> #include <sqlite3.h>int main(int argc, cha…

linux網絡編程(四)線程池

linux網絡編程&#xff08;四&#xff09;線程池為什么會有線程池&#xff1f;實現簡單的線程池為什么會有線程池&#xff1f; 大多數的服務器可能都有這樣一種情況&#xff0c;就是會在單位時間內接收到大量客戶端請求&#xff0c;我們可以采取接受到客戶端請求創建一個線程的…

AIGC:大語言模型LLM的幻覺問題

引言 在使用ChatGPT或者其他大模型時&#xff0c;我們經常會遇到模型答非所問、知識錯誤、甚至自相矛盾的問題。 雖然大語言模型&#xff08;LLMs&#xff09;在各種下游任務中展示出了卓越的能力&#xff0c;在多個領域有廣泛應用&#xff0c;但存在著幻覺的問題&#xff1a…

關于C++子類父類成員函數的覆蓋和隱藏

轉載&#xff1a;http://blog.csdn.net/worldmakewayfordream/article/details/46827161 函數的覆蓋 覆蓋發生的條件&#xff1a; &#xff08;1&#xff09; 基類必須是虛函數&#xff08;使用virtual 關鍵字來進行聲明&#xff09; &#xff08;2&#xff09;發生覆蓋的兩個函…

數據結構(四)串的順序存儲

#include <stdio.h> #include <stdlib.h>#define MAXLEN 255 //定長順序存儲 typedef struct {char ch[MAXLEN]; //每個分量存儲一個字符int length; //串的實際長度 }SString;//串的初始化 bool StrAssign(SString& T, char* chars) {int i 0, len;char* …

數據結構(四)串的動態數組存儲

#include <stdio.h> #include <stdlib.h>#define MAXLEN 255 //定長順序存儲 typedef struct {char* ch; //每個分量存儲一個字符int length; //串的實際長度 }SString;//串的初始化 bool StrAssign(SString& T, char* chars) {int i 0, len;T.ch (char*)m…