Linux中的阻塞信號與信號原理

在Linux操作系統中,信號(Signal)是進程間通信和進程控制的核心機制之一。信號是一種異步通知機制,可以向進程發送異步事件通知,以便進程能夠處理系統級別的事件。本文將詳細探討Linux中的信號原理,重點講解阻塞信號的機制及其使用。

一、Linux信號的基本概念

1. 什么是信號

信號是一種輕量級的異步通知機制,通常用于通知進程發生了某種事件。信號可以由內核、用戶或進程本身產生。例如,當用戶按下?Ctrl+C?時,系統會向前臺進程發送?SIGINT?信號,通知進程終止。

2. 常見信號

一些常見的Linux信號包括:

  • SIGHUP:掛起信號,通常在終端斷開連接時發送。
  • SIGINT:中斷信號,通常由?Ctrl+C?觸發,要求進程終止。
  • SIGKILL:強制終止信號,不能被捕獲或忽略,立即終止進程。
  • SIGTERM:終止信號,程序可以捕獲并執行清理工作后退出。
  • SIGSEGV:無效內存訪問信號,通常在程序訪問未分配的內存時觸發。

二、信號處理機制

信號可以被進程捕獲、忽略或使用默認處理方式。對于每種信號,進程都可以設置一個信號處理函數,當信號發生時,操作系統會調用該函數。

1. 注冊信號處理函數

使用?signal()?函數可以注冊一個信號處理函數:

#include <signal.h>
#include <stdio.h>
#include <unistd.h>void handle_sigint(int sig) {printf("Caught signal %d\n", sig);
}int main() {signal(SIGINT, handle_sigint);while (1) {printf("Running...\n");sleep(1);}return 0;
}

解釋:在上面的代碼中,當進程收到?SIGINT?信號時(如按下?Ctrl+C),handle_sigint()?函數會被調用,從而在終端打印信號編號。

2. 信號的默認處理

如果進程沒有為信號指定處理函數,操作系統會執行默認處理。例如,SIGKILL?信號的默認行為是立即終止進程,SIGSEGV?信號的默認行為是終止進程并生成內核轉儲(core dump)。

三、阻塞信號

阻塞信號是一種控制信號傳遞的機制。通過阻塞信號,進程可以暫時阻止某些信號的處理,直到解除阻塞為止。這對于保護關鍵代碼段非常有用,確保在執行關鍵操作時不會被信號中斷。

1. 使用?sigprocmask?阻塞信號

sigprocmask?函數用于檢查和更改進程的信號掩碼(signal mask),從而控制信號的阻塞。

#include <signal.h>
#include <stdio.h>
#include <unistd.h>int main() {sigset_t set;sigemptyset(&set);sigaddset(&set, SIGINT);// 阻塞SIGINT信號sigprocmask(SIG_BLOCK, &set, NULL);printf("SIGINT is blocked\n");sleep(10);// 解除阻塞sigprocmask(SIG_UNBLOCK, &set, NULL);printf("SIGINT is unblocked\n");while (1) {sleep(1);}return 0;
}

解釋:在上面的代碼中,我們首先創建一個空的信號集?set,然后將?SIGINT?添加到這個信號集中。通過?sigprocmask?函數,我們阻塞了?SIGINT?信號。此時,即使用戶按下?Ctrl+C,進程也不會立即響應。10秒后,我們解除阻塞,進程恢復對?SIGINT?的處理。

2. 使用?sigsuspend?進行信號等待

sigsuspend?函數用于暫時替換進程的信號掩碼,并掛起進程直到接收到信號。常用于實現安全的信號等待操作。

#include <signal.h>
#include <stdio.h>
#include <unistd.h>void handle_sigint(int sig) {printf("Caught signal %d\n", sig);
}int main() {signal(SIGINT, handle_sigint);sigset_t set, oldset;sigemptyset(&set);sigaddset(&set, SIGINT);// 阻塞SIGINT信號sigprocmask(SIG_BLOCK, &set, &oldset);printf("Waiting for SIGINT\n");// 暫時解除阻塞,并掛起進程等待信號sigsuspend(&oldset);printf("Resuming execution\n");return 0;
}

解釋:sigsuspend?函數接收一個信號集作為參數,并暫時將其作為新的信號掩碼,然后掛起進程直到接收到信號。信號處理函數處理完信號后,進程恢復執行。

四、信號阻塞與處理的應用場景

阻塞信號的常見應用場景包括:

  • 關鍵代碼保護:在執行關鍵操作時,阻塞信號可以防止因信號中斷而導致的不一致狀態。
  • 同步多線程:在多線程編程中,主線程可以阻塞特定信號,而讓其他線程處理該信號,從而實現線程間的同步。
  • 復雜信號處理:在需要處理多個信號或需要確保特定順序的信號處理時,可以使用阻塞和解除阻塞的機制來實現。

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

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

相關文章

QT學習教程(三十五)

事件處理&#xff08;- Event Processingn&#xff09; 事件是視窗系統或者Qt 本身在各種不同的情況下產生的。當用戶點擊或者釋放鼠標&#xff0c;鍵盤時&#xff0c;一個鼠標事件或者鍵盤事件就產生了。當窗口第一次顯示時&#xff0c;一個繪制事件會產生告訴新可見的窗口繪…

【Dify 案例】【MCP實戰】【三】【超級美食家】

接上次的超級助理,我們這一期給出一個超級美食家 首先:我的MCP要申請一個key ` 我們來看看這個MCP服務怎么使用呢。`https://modelscope.cn/mcp/servers/@worryzyy/howtocook-mcp插件里面需要配置 {"mcpServers":{"amap-amap-sse":{"url":&qu…

4.文件管理(文本、日志、Excel表)

目錄 1.文本 2.日志 3.Excel表 1.文本 using System.Text;namespace (自己創建的一個類) {/// <summary>/// 配置文件*.ini讀寫器。/// </summary>public class IniFile{[System.Runtime.InteropServices.DllImport("kernel32")]private static ex…

Java 包裝類詳解

什么是包裝類 Java包裝類&#xff08;Wrapper Classes&#xff09;是將8種基本數據類型封裝成對象的類&#xff0c;位于java.lang包中。每個基本數據類型都有對應的包裝類&#xff1a; byte → Byteshort → Shortint → Integerlong → Longfloat → Floatdouble → Doublec…

阿里云ACP認證-數據倉庫

數據倉庫 Kappa架構&#xff1a;將實時和離線代碼統一&#xff08;優化lambda架構&#xff09;&#xff0c;但是不好修正數據&#xff0c;開發周期長&#xff0c;成本浪費&#xff0c;對于歷史數據的高吞吐量力不從心 原一代數據倉庫&#xff1a; 離線&#xff1a;hivemaxcom…

WebRTC(五):TURN協議

TURN&#xff08;Traversal Using Relays around NAT&#xff09;協議是一個網絡協議&#xff0c;旨在解決 NAT&#xff08;網絡地址轉換&#xff09;和防火墻 環境下的 UDP/TCP通信問題。它通常與 STUN 和 ICE 協議一起使用&#xff0c;廣泛應用于 WebRTC、SIP 和視頻會議等實…

Python 的內置函數 hasattr

Python 內建函數列表 > Python 的內置函數 hasattr Python 的內置函數 hasattr() 用于檢查一個對象是否具有指定的屬性或方法。該函數的語法為&#xff1a; hasattr(object, name)參數說明&#xff1a; object&#xff1a;要檢查的對象&#xff0c;可以是任何 Python 對象…

docker使用技巧之把擴展卷命名變成有意義

背景 之前使用別人的鏡像之后&#xff0c;啟動docker后發出現了一堆看不懂名稱的擴展卷 eg&#xff1a;集群查看 擴展卷查看 這個時候如果有很多集群需要清理擴展卷就很麻煩&#xff0c;不知道是哪個集群的 操作步驟 可以實現的分析&#xff1a;這個擴展卷的信息應該是和…

《博物通書》《博物新編》與滿清歷史篡改

《博物新編》作為近代西方科技輸入中國的首部著作&#xff0c;其問世猶如一顆投入平靜湖面的巨石&#xff0c;在 19 世紀中期的中國激起層層漣漪&#xff0c;對中國近代科學發展產生了多維度、深層次的影響。它不僅是知識傳播的載體&#xff0c;更是推動中國科學從傳統走向近代…

【入門】【例18.1】 睡眠

| 時間限制&#xff1a;C/C 1000MS&#xff0c;其他語言 2000MS 內存限制&#xff1a;C/C 64MB&#xff0c;其他語言 128MB 難度&#xff1a;中等 分數&#xff1a;100 OI排行榜得分&#xff1a;12(0.1分數2難度) 出題人&#xff1a;root | 描述 一個人只有每天睡眠時間到達 8…

DAY 38 Dataset和Dataloader類

知識點回顧&#xff1a; Dataset類的__getitem__和__len__方法&#xff08;本質是python的特殊方法&#xff09;Dataloader類minist手寫數據集的了解 作業&#xff1a;了解下cifar數據集&#xff0c;嘗試獲取其中一張圖片 import torch import torch.nn as nn import torch.o…

【Kubernetes】以LOL的視角打開K8s

前言 對于大部分后端程序員乃至于非后端程序員來說&#xff0c;在當前的云原生時代&#xff0c;Kubernetes&#xff08;后稱K8s&#xff09;都是繞不開的一項技術&#xff1b;同時&#xff0c;對于這個時代的程序員來說&#xff0c;“英雄聯盟”&#xff08;后稱LOL&#xff0…

UE5 游戲模板 —— FirstShootGame

UE5 游戲模板 —— FirstShootGame 前言一、GameMode二、組件1.ShooterPickUpComponent單播多播 2.ShooterWeaponComponent附著武器開火 3.小結4.ShooterProjectile初始化碰撞受擊檢測 三、Character初始化輸入移動 總結 前言 有了前兩個俯視角游戲的基礎讓我們來看看相對復雜…

國家級與省級(不含港澳臺)標準地圖服務網站匯總

在先前的文章中&#xff0c;介紹了部分省級的標準地圖服務網站可以下載各個區縣近幾年、不同要素的標準地圖&#xff08;鏈接&#xff1a;國家與省市縣 標準地圖服務網站 審圖號地圖下載&#xff09;&#xff0c;但是當時只匯總了部分省級的標準地圖服務網站。 這兩天看到了一個…

前端開發面試題總結-vue3框架篇(一)

文章目錄 Vue3高頻問答一、vue2/vue3中常用的構建工具和腳手架分別是什么? 有什么區別?二、請說一說vue2和vue3的區別&#xff1f;三、請說一說vue2和vue3響應式原理的區別&#xff1f;四、vue3 如何定義響應式數據?五、說一說你對vue3中的setup函數?六、說一說vue3中的路由…

【LLM06---相對位置編碼】

文章目錄 相對位置編碼經典式XLNET式T5式DeBERTa式 相對位置編碼 上一節我們介紹了絕對位置編碼&#xff0c;這一節我們來看相對位置編碼&#xff0c;也就是用相對位置信息來表示&#xff0c;之前每一個token的位置式通過一個絕對的位置向量來表示的&#xff0c;現在我們在計算…

純跟蹤算法本質解密:航向角偏差=預瞄角?數學證明與工程實踐

定義關鍵問題 在深入純跟蹤算法核心前&#xff0c;必須澄清一對容易被混淆但至關重要的概念&#xff1a; 概念坐標系物理意義計算方式航向角偏差(α_global)全局坐標系車輛航向與預瞄點方向的夾角預瞄點方位角 - 車輛航向角預瞄角(α_body)車身坐標系預瞄點相對于車輛縱軸的夾…

自動駕駛叉車在倉庫環境中是否安全?

隨著自動駕駛叉車的興起&#xff0c;倉庫運營持續演進。叉車自動化技術的引入使倉庫設施變得更快、更安全且更具成本效益。然而一個關鍵問題依然存在&#xff1a;它們在繁忙的倉庫環境中是否安全&#xff1f; 一 、什么是自動駕駛叉車&#xff1f; 自動駕駛叉車&#xff0c;也…

Neo4j操作指南:修改節點數據與新增節點屬性

Neo4j操作指南&#xff1a;修改節點數據與新增節點屬性 引言 Neo4j作為領先的圖數據庫&#xff0c;提供了靈活的數據操作方式。在實際應用中&#xff0c;我們經常需要修改已有節點的數據或為節點添加新屬性。本文將詳細介紹如何使用Cypher查詢語言在Neo4j中完成這些操作&…

AI大模型學習之基礎數學:微積分在AI大模型中的核心-梯度與優化(梯度下降)詳解

微積分在AI大模型中的核心:梯度與優化(梯度下降) 人工智能(AI)大模型的訓練和優化依賴于數學基礎,其中微積分、線性代數和概率統計構成了其理論核心。微積分在AI中的核心作用在于提供優化工具,尤其是通過梯度和梯度下降方法,幫助模型在高維參數空間中找到損失函數的最…