Linux—信号(day09)

目录

一、使用C程序访问环境变量

二、文件输入重定向

三、管道

四、信号


 

 

四、信号

  信号就是软件模拟的中断,信号是进程的异步通讯机制。

  如何查看系统提供的信号:kill -l,下面的数字为信号的编号,编号后面的字符为信号的名称。

man 7 signal,可查看信号帮助

 通过shell向进程发送信号,kill -信号编号 pid

  总的来说,信号有以下几个过程:信号的产生,可能有信号阻塞、信号未决(信号传输这一段时间)、进程捕获信号,信号处理

  进程对信号的默认处理动作就是会终止当前进程,用户可以根据自己的需求来设置对信号的处理。主要有以下:

  SIG_DEL(缺省的,默认处理状态)、SIG_IGN(忽略信号)、用户自定义信号处理函数


信号处理:

  如需使用自定义函数,则需要向进程注册一个函数,当信号到来的时候,使用注册的信号处理函数来处理到达的信号。注册函数使用signal(2)

 

#include <signal.h>
typedef void (*sighandler)(int); sighandler signal(int signum,sighandler handler);
功能:
  为信号注册处理函数
参数:
  signum:信号的名字或编号
  handler:
    SIG_DEL:默认
    SIF_IGN:忽略
    用户自定义的信号处理函数
返回值:
  错误:SIG_ERR
  成功:返回注册前的信号处理函数 

1、默认处理情况
  直接在主函数中写一个死循环,再向进程发送信号,进程就会终止
2、忽略处理
#include<stdio.h>
#include<signal.h>
int main(void){ 
signal(
2,SIG_IGN);
while(1);

return 0;
}

3、自定义处理

#include<stdio.h>
#include<signal.h>
void doit(int n){
    printf("recv signal...\n");
    return;
}
int main(void){ 
    signal(2,SIG_IGN);
    signal(3,doit);
    while(1); 
   
    return 0; 
}

 

信号的产生:

1、硬件产生信号
 ctrl+c、ctrl+\等
2、使用linux命令
 kill -信号编号 pid
3、使用函数发送信号
kill(2)
#include<sys/types.h>
#include<signal.h>
int kill(pid_t pid,int sig);
功能:
  发送一个信号给一个进程或进程组
参数:
  pid:
    如果pid为正,则为指定pid进程发送信号
    如果pid为0,则为进程组的每一个进程都发送信号
    如果为-1,发送给所有与发送信号进程有相同权限的进程(init除外)
    如果pid比-1还小,那么sig就被发送给id是-pid的所有进程
  sig:
    0,不发送信号,但是仍然检测错误,可以用来检测PID或者PPID是否存在
    非0:指定信号编号
返回值:
   成功:0
   错误:-1,errno被设置 

信号接收处理程序
#include<stdio.h>
#include<signal.h>
void doit(int n){
    printf("recv signum%d\n",n);
    return;
}
int main(void){ 
    printf("pid%d\n",getpid());
    signal(2,doit);
    while(1); 
    return 0; 
}

信号发送程序

#include<stdio.h>
#include<signal.h>
#include<sys/types.h>

int main(int argc,char *argv[]){
    //通过可执行程序名+ 信号编号+pid发送信号
    int signum=atoi(argv[1]);
    pid_t pid=atoi(argv[2]);
    kill(pid,signum);
    return 0;
}

 

raise(3)

#include<signal.h>
int raise(int sig);
功能:
  发送一个信号给调用者
参数:
  sig:要发送的信号编号
返回值:
  成功:0
  失败:非0

使用raise给自己发送信号:
#include<stdio.h>
#include<signal.h>
void doit(int n){
    printf("recv signum%d\n",n);
    return;
}
int main(void){ 
    printf("pid%d\n",getpid());
    signal(2,doit);
    while(1){
        sleep(2);
        raise(2);
    }
    return 0; 
}
 
 

alarm(2)

#include<unistd.h>

unsigned int alarm(unsigned int seconds);

功能;

  设置一个传递信号的闹钟

参数:

  seconds:设置闹钟秒数

返回值:

  保留的秒数;参数seconds为0时,之前设置的定时器闹钟将被取消,并将剩下的时间返回

 
 
#include<stdio.h>
#include<unistd.h>
int main(void){
    int i;
    alarm(1)
    for(i=0;;i++){
        printf("%d\n",i);
    }  
    return 0;
}
 
 

 

 

 

转载于:https://www.cnblogs.com/ptfe/p/11017522.html

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值