信号:

信号是通知发生了某种事件的机制,内核和进程都可能会向进程发送各种信
号,进程也可以向自己发送信号。系统定义了一组标准信号类型,每种信号都拥
有唯一的数值和用途。
典型的信号递送是异步的,意味着进程可能会在任何时候被信号中断。在某
些情况下(如硬件产生的信号),信号也可能会被同步递送,意味着信号递送是
可预测的,并且可以在程序执行期间特定时间点重新产生。
信号的默认动作可能是忽略、终止进程(生成或不生成 core dump 文件)、
停止进程执行、继续执行已停止的进程。不同信号类型的默认动作是不一样的。
此外程序可以使用 signal()或 sigaction()显式地忽略一个信号,或者建立程序员自
定义的信号处理器。由于可移植性等原因,我们最好使用 sigaction()来建立信号
处理器。
进程(拥有适当的权限)可以使用 kill()向其它进程发送信号。发送 null 信号
(0)可以检测特定进程 ID 是否正被系统使用。
每个进程都拥有一个信号掩码,也就是当前阻塞递送的信号集。我们可以使
用 sigprocmask()向信号掩码中添加或删除信号。
如果一个信号在被阻塞时接收到,会保持未决直到该信号被解除阻塞。标准
信号不会被排队,也就是说一个信号只会被标记为未决一次,稍后也只会被递送

一次。进程可以使用 sigpending()系统调用来获取当前未决的信号集。

sigaction()系统调用在设置信号部署(当有信号来时,被调用的函数)时,能够提供比 signal()更多的控制选项

和灵活性。首先我们可以指定一组额外的信号,在信号处理器被调用时进行阻塞。
此外还可以使用许多标志来控制信号处理器被调用时的各种动作。例如有些标志
可以选择使用老式的不可靠信号语义(不阻塞导致信号处理器调用的当前信号,
以及调用信号处理器之前重置信号的部署为默认动作)。
使用 pause()可以暂停进程的执行,直到某个信号到达。

注意:信号处理器是异步的,在多线程情况下,要避免使用不可重入的库函数。

实时信号:

  信号发送的次数,但是因为并发的原因,在内核调用进程的时间间隔内,普通信号的调用次数被记录为一次。

  实时信号会维持一个队列,来记录所有的实时信号,但是这个队列长度是有限制的。

  并且实时信号可以携带少量的数据。通过int数据或者携带一个指针(在信号中不常用)。通过sigqueue()系统调用发送实时信号。

同步信号等待:

  首先要阻塞住需要等待的信号,不然它们会调用相应的信号处理器。通过waitsiginfo()函数可以阻塞进程来等待信号。从而实现进程同步。

定时器:

  用setimer()和alarm()可以定时给进程发送信号,它们共享同一进程的同一实时信号

  可以用来实现定时器的其他函数:sleep(), nanosleep(), POSIX时钟用clocktime来计时

linux下进程通信总结的更多相关文章

  1. Linux下进程通信的八种方法

    Linux下进程通信的八种方法:管道(pipe),命名管道(FIFO),内存映射(mapped memeory),消息队列(message queue),共享内存(shared memory),信号量 ...

  2. [置顶] 简单解析linux下进程通信方法

    linux下的进程通信手段基本上是从Unix平台上的进程通信手段继承而来的.而对Unix发展做出重大贡献的两大主力AT&T的贝尔实验室及BSD(加州大学伯克利分校的伯克利软件发布中心)在进程间 ...

  3. Linux下进程通信之管道

    每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷到内核缓冲区,进程2再从内核缓冲区把 ...

  4. Linux下进程间管道通信小作业

    在进行这次作业之前,我们先来看看什么是管道吧! 管道是Linux中很重要的一种通信方式,是把一个程序的输出直接连接到另一个程序的输入,常说的管道多是指无名管道,无名管道只能用于具有亲缘关系的进程之间, ...

  5. Linux下进程的建立

    Linux下进程的建立 我们都知道,进程就是正在执行的程序.而在Linux中,可以使用一个进程来创建另外一个进程.这样的话,Linux的进程的组织结构其实有点像Linux目录树,是个层次结构的,可以使 ...

  6. Linux之进程通信20160720

    好久没更新了,今天主要说一下Linux的进程通信,后续Linux方面的更新应该会变缓,因为最近在看Java和安卓方面的知识,后续会根据学习成果不断分享更新Java和安卓的方面的知识~ Linux进程通 ...

  7. 【网络编程基础】Linux下进程通信方式(共享内存,管道,消息队列,Socket)

    在网络课程中,有讲到Socket编程,对于tcp讲解的环节,为了加深理解,自己写了Linux下进程Socket通信,在学习的过程中,又接触到了其它的几种方式.记录一下. 管道通信(匿名,有名) 管道通 ...

  8. 【Linux】Linux下进程间的通信方式

    本文内容: 1.进程通信的目的 2.介绍Linux下进程间的4种通信方式:管道,消息队列,共享内存,信号量 ps:套接字也可以用于进程间的通信,不过是不同物理机器上的进程通信,本章讨论是是同一台物理机 ...

  9. linux 下进程通讯详解

    linux 下进程通讯方法主要有以下六种: 1.管道 2.信号 3.共享内存 4.消息队列 5.信号量 6.socket

  10. 【Linux下进程机制】从一道面试题谈linux下fork的运行机制

    今天一位朋友去一个不错的外企面试linux开发职位,面试官出了一个如下的题目: 给出如下C程序,在linux下使用gcc编译: #include "stdio.h" #includ ...

随机推荐

  1. 编译OpenCV以及openc_contrib提示缺少boostdesc_bgm.i文件出错的解决

    ~/opencv_contrib/modules/xfeatures2d/src/boostdesc.cpp:673:20: fatal error: boostdesc_bgm.i: No such ...

  2. Hystrix容错监控机制

    六:Hystrix容错监控机制 什么是微服务的容错机制 提前预设解决方案.,系统自主调节,遇到问题即时处理 什么是Hystrix Netfix 设计原则: 服务隔离机制 服务降级 熔断机制 提供实时的 ...

  3. 【Raspberry Pi / 树莓派】小小工控机担起大大责任

    CM4 Nano是一款基于Raspberry Pi / 树莓派 Compute Module 4(简称CM4),由EDATEC面向工业应用设计的嵌入式计算机, 充分利用CM4在结构上灵活性解决CPU, ...

  4. 大规模 IoT 边缘容器集群管理的几种架构-2-HashiCorp 解决方案 Nomad

    前文回顾 大规模 IoT 边缘容器集群管理的几种架构-0-边缘容器及架构简介 大规模 IoT 边缘容器集群管理的几种架构-1-Rancher+K3s ️Reference: IoT 边缘计算系列文章 ...

  5. 有理数四则运算 PTA1034

    题目:https://pintia.cn/problem-sets/994805260223102976/problems/994805287624491008 本题要求编写程序,计算 2 个有理数的 ...

  6. CCRD_TOC_2007_EULAR专辑_2

    中信国健临床通讯 EULAR 2007专辑II 目录 类风湿关节炎 1 Etanercept联合MTX治疗RA导致炎症与骨破坏进展之间的失关联也见于单关节水平:来自TEMPO的研究数据 Landewe ...

  7. Java第三讲动手动脑

    1 以上代码无法通过编译主要是由于在Foo类中自定义了有参的构造函数,系统不在提供默认的构造函数(无参),而在上述的引用中并没有提供参数导致无法通过编译. 2. 运行结果 由运行结果分析可知,在运行时 ...

  8. mysql数据库总是锁表

    有可能是数据库服务器的磁盘空间满了

  9. tp-link路由器后台_硬解

    title: 脚本_tp-link路由器后台_硬解 author: 杨晓东 permalink: 脚本 date: 2021-10-02 11:27:04 categories: - 投篮 tags: ...

  10. 00.IDEA的使用

    1.IDEA的必备常用快捷键 复制本行到下一行:ctrl D 删除一行代码:ctrl Y 替换文本:ctrl R 根据光标放的位置提供快速修复选择:Alt + Enter 生成返回值:ctrl alt ...