linux下基于C语言的信号编程实例

本文实例讲述了linux下基于C语言的信号编程方法。分享给大家供大家参考。具体如下:

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
void sig_handler(int sig_no, siginfo_t *info, void *ctext){
  printf("receive sig_no=%d\n",sig_no);
  if(sig_no == SIGQUIT){
    printf("haha,想退出了吗?");
  }else{
    printf("si_signo=%d\n",info->si_signo);
    printf("si_code =%d\n",info->si_code);
    printf("si_pid =%d\n",info->si_pid);
    printf("si_uid =%d\n",info->si_uid);
    printf("si_status=%d\n",info->si_status);
    printf("si_utime =%lld\n",info->si_utime);
    printf("si_stime =%lld\n",info->si_stime);
    printf("si_value =%d\n",info->si_value);
    printf("si_addr =0x%x\n",info->si_addr);
    printf("si_fd  =%d\n",info->si_fd);
  }
  return ;
}
/*--------------------常用信号列表----------------------------*/
//SIGINT ctrl+c
//SIGQUIT ctrl+\
//SIGPIPE 管道破裂
//SIGKILL 进程终止,不能被捕获
//SIGHUP shell退出
//SIGCHLD 子进程终止信号
//SIGFPE 浮点数异常(除以0之类的)
//SIGTERM 终止信号(kill pid)
int main(int argc ,char **argv){
  struct sigaction sa;
  sa.sa_flags  = 0;
  sa.sa_sigaction = sig_handler;
  sa.sa_flags  |= SA_SIGINFO;  //使用sa_sigaction作为回调
  //sa.sa_flags |= SA_RESETHAND; //处理函数只会被调用一次,之后被重置
  //sa.sa_flags |= SA_NOCLDSTOP; //如果安装了SIGCLD,子进程不是正常退出,而是被kill掉了,则不会通知
  //sa.sa_flags |= SA_NODEFER ;  //使对信号的屏蔽无效,即在信号处理函数执行期间仍能发出这个信号
  //sa.sa_flags |= SA_RESTART ;  //使被信号打断的系统调用自动重新发起
  //sa.sa_flags |= SA_NOCLDWAIT; //使父进程在它的子进程退出时不会收到 SIGCHLD 信号,这时子进程如果退出也不会成为僵尸进程
  //安装信号
  if(sigaction(SIGINT,&sa,NULL)==-1) printf("安装信号失败\n");
  if(sigaction(SIGQUIT,&sa,NULL)==-1) printf("安装信号失败\n");
  while(1){
    sleep(1);
  }
  return 0;
}
/*--------------------------信号编程相关结构体----------------------------------*/
 // struct sigaction {
 //   void (*sa_handler)(int);
 //   void (*sa_sigaction)(int, siginfo_t *, void *);
 //   sigset_t sa_mask;
 //   int sa_flags;
 //   void (*sa_restorer)(void);
 // }
// siginfo_t {
//    int   si_signo; /* Signal number */
//    int   si_errno; /* An errno value */
//    int   si_code;  /* Signal code */
//    pid_t  si_pid;  /* Sending process ID */
//    uid_t  si_uid;  /* Real user ID of sending process */
//    int   si_status; /* Exit value or signal */
//    clock_t si_utime;  //User time consumed
//    clock_t si_stime; /* System time consumed */
//    sigval_t si_value; /* Signal value */
//    int   si_int;  /* POSIX.1b signal */
//    void *  si_ptr;  /* POSIX.1b signal */
//    void *  si_addr;  /* Memory location which caused fault */
//    int   si_band;  /* Band event */
//    int   si_fd;   /* File descriptor */
// }
// 信号    值      动作 解释
// SIGHUP  1          终端线路挂断
// SIGINT  2      Term  键盘输入的中断命令,从终端输入 Ctrl-C 时发生
// SIGQUIT 3      Core  键盘输入的退出命令
// SIGILL  4      Core  错误指令
// SIGABRT 6      Core  abort(3)发出的中止信号
// SIGFPE  8      Core  浮点数异常
// SIGKILL 9      Term  KILL信号
// SIGSEGV 11      Core  非法内存访问
// SIGPIPE 13      Term  管道断开
// SIGALRM 14      Term  alarm(2)发出的中止信号
// SIGTERM 15      Term  强制中止信号
// SIGUSR1 30,10,16   Term  用户自定义信号1
// SIGUSR2 31,12,17   Term  用户自定义信号2
// SIGCHLD 20,17,18   Ign  子进程中止信号
// SIGCONT 19,18,25   Cont  继续执行一个停止的进程
// SIGSTOP 17,19,23   Stop  非终端来的停止信号
// SIGTSTP 18,20,24   Stop  终端来的停止信号
// SIGTTIN 21,21,26   Stop  后台进程读终端
// SIGTTOU 22,22,27   Stop  后台进程写终端

希望本文所述对大家的C语言程序设计有所帮助。

(0)

相关推荐

  • linux shell中 if else以及大于、小于、等于逻辑表达式介绍

    比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示条件测试. 注意:这里的空格很重要.要确保方括号的空格.笔者就曾因为空格缺少或位置不对,而浪费好多宝贵的时间. if ....; then....elif ....; then....else....fi[ -f "somefile" ] :判断是否是一个文件[ -x "/bin/ls" ] :判断/bin/ls是否存在并有可执行权限[ -n "$var" ]

  • linux多线程编程详解教程(线程通过信号量实现通信代码)

    线程分类 线程按照其调度者可以分为用户级线程和核心级线程两种. (1)用户级线程 用户级线程主要解决的是上下文切换的问题,它的调度算法和调度过程全部由用户自行选择决定,在运行时不需要特定的内核支持.在这里,操作系统往往会提供一个用户空间的线程库,该线程库提供了线程的创建.调度.撤销等功能,而内核仍然仅对进程进行管理.如果一个进程中的某一个线程调用了一个阻塞的系统调用,那么该进程包括该进程中的其他所有线程也同时被阻塞.这种用户级线程的主要缺点是在一个进程中的多个线程的调度中无法发挥多处理器的优势.

  • Linux下semop等待信号时出现Interrupted System Call错误(EINTR)解决方法

    错误现象:(semop函数调用,strerror(errno)输出结果)Interrupted system call平台:RedHat Linux LINUX文档关于EINTR的描述是这样子的:  While blocked in this system call, the process caught a signal.UNIX文档[IEEE Std 1003.1-2008]关于EINTR的描述是这样子的:  The semop() function was interrupted by a

  • Android获取当前已连接的wifi信号强度的方法

    本文实例讲述了Android获取当前已连接的wifi信号强度的方法,是Android程序开发中非常常见的重要技巧.分享给大家供大家参考之用.具体方法如下: 1.得到当前已连接的wifi信息 WifiManager wifi_service = (WifiManager)getSystemService(WIFI_SERVICE); WifiInfo wifiInfo = wifi_service.getConnectionInfo(); 其中wifiInfo有以下的方法: wifiinfo.ge

  • Python Web框架Flask信号机制(signals)介绍

    信号(signals) Flask信号(signals, or event hooking)允许特定的发送端通知订阅者发生了什么(既然知道发生了什么,那我们可以知道接下来该做什么了). Flask提供了一些信号(核心信号)且其它的扩展提供更多的信号.信号是用于通知订阅者,而不应该鼓励订阅者修改数据.相关信号请查阅文档. 信号依赖于Blinker库. 钩子(hooks) Flask钩子(通常出现在蓝图或应用程序现存的方法中,比如一些内置装饰器,例如before_request)不需要Blinker

  • Linux系统(X64)安装Oracle11g完整安装图文教程另附基本操作

    一.修改操作系统核心参数 在Root用户下执行以下步骤: 1)修改用户的SHELL的限制,修改/etc/security/limits.conf文件 输入命令:vi /etc/security/limits.conf,按i键进入编辑模式,将下列内容加入该文件. oracle soft nproc 2047 oracle hard nproc 16384 oracle soft nofile 1024 oracle hard nofile 65536 编辑完成后按Esc键,输入":wq"

  • java信号量控制线程打印顺序的示例分享

    复制代码 代码如下: import java.util.concurrent.Semaphore; public class ThreeThread { public static void main(String[] args) throws InterruptedException {  Semaphore sempA = new Semaphore(1);  Semaphore sempB = new Semaphore(0);  Semaphore sempC = new Semapho

  • Linux下的信号详解及捕捉信号

    信号的基本概念 每个信号都有一个编号和一个宏定义名称 ,这些宏定义可以在 signal.h 中找到. 使用kill -l命令查看系统中定义的信号列表: 1-31是普通信号: 34-64是实时信号 所有的信号都由操作系统来发! 对信号的三种处理方式 1.忽略此信号:大多数信号都可使用这种方式进行处理,但有两种信号却决不能被忽略.它们是:SIGKILL和SIGSTOP.这两种信号不能被忽略的,原因是:它们向超级用户提供一种使进程终止或停止的可靠方法.另外,如果忽略某些由硬件异常产生的信号(例如非法存

  • Linux线程同步之信号C语言实例

    linux中向某个线程发送信号,若没有对该信号的处理函数,则会导致程序结束. 如下面的程序,创建一个线程,主线程向其发送一个信号,会导致程序立即结束 #include <stdio.h> #include <pthread.h> pthread_t t; void* run(void* arg) { while(1) { printf("Hello\n"); } } main() { pthread_create(&t, 0, run, 0); pthr

  • linux下基于C语言的信号编程实例

    本文实例讲述了linux下基于C语言的信号编程方法.分享给大家供大家参考.具体如下: #include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <unistd.h> #include <signal.h> void sig_handler(int sig_no, siginfo_t *info, void *ctext){ printf("receive si

  • linux下的C\C++多进程多线程编程实例详解

    linux下的C\C++多进程多线程编程实例详解 1.多进程编程 #include <stdlib.h> #include <sys/types.h> #include <unistd.h> int main() { pid_t child_pid; /* 创建一个子进程 */ child_pid = fork(); if(child_pid == 0) { printf("child pid\n"); exit(0); } else { print

  • linux下通过go语言获得系统进程cpu使用情况的方法

    本文实例讲述了linux下通过go语言获得系统进程cpu使用情况的方法.分享给大家供大家参考.具体分析如下: 这段代码通过linux的系统命令 ps来分析cpu的使用情况,代码如下: 复制代码 代码如下: package main import (     "bytes"     "log"     "os/exec"     "strconv"     "strings" ) type Process s

  • linux 下实现sleep详解及简单实例

    linux 下实现sleep详解及简单实例 sleep: 普通版本 1.基本设计思路: 1>注册SIGALRM信号的处理函数:    2>调用alarm(nsecs)设定闹钟: 3>调⽤pause等待,内核切换到别的进程运行: 4>nsecs秒之后,闹钟超时,内核发SIGALRM给这个进程 ; 5>从内核态返回这个进程的⽤户态之前处理未决信号,发现有SIGALRM信号,其处理函数是sig_alrm; 6> 切换到用户态执行sig_alrm函数,进⼊sig_alrm函数时

  • linux下开启php的sockets扩展支持实例

    下个相同版本的php源码,进行编译安装,再按照上面步骤搞,生成的so.copy到rpm装的那个,修改php.ini进行扩展就行了, 或者到网上找相同版本,相同系统 的编译好的so文件. 在linux下给PHP安装socket扩展,参考方法如下: #cd /usr/soft/php/ext/sockets (进入原php安装文件下的sockets目录) #/usr/local/php/bin/phpize (运行安装后的php安装文件下的phpize) #./configure --prefix=

  • Linux下重启oracle服务及监听器和实例详解

    一.在Linux下重启Oracle数据库及监听器: 方法1: 用root以ssh登录到linux,打开终端输入以下命令: cd $ORACLE_HOME #进入到oracle的安装目录 dbstart #重启服务器 lsnrctl start #重启监听器 cd $ORACLE_HOME #进入到oracle的安装目录 dbstart #重启服务器 lsnrctl start #重启监听器 ----------------------------------- 方法2: Sql代码 cd $OR

  • 对Linux下shell编程之for循环的实例讲解

    linux 下 for 循环中可以使用 break 和 continue 关键字来跳出循环, 和java 用法一致 一.常用for循环结构 #语法一 for 变量 in 值1 值2 值3.. do 程序块儿 done # #语法二 for 变量 `命令` do 程序块儿 done # #语法三 for ((初始值; 循环控制; 变量变化)) do 程序块儿 done 二.常用测试结构 1. 输出3次uptime #!/bin/bash for i in 1 2 3 4 5 do echo "$i

  • Java基于Tcp协议的socket编程实例

    本文实例讲述了Java基于Tcp协议的socket编程方法,分享给大家供大家参考.具体分析如下: 以下是一对一的通信编程实现,后续会继续学习一个服务器监听多个客户端的实现. 这里用到的主要步骤如下: 第一步:以特定端口(如4800)新建socket对象 第二步:以系统输入设备构造BufferedReader对象,该对象用于接收系统键盘输入的字符 第三步:以socket对象 得到输出流来构造PrintWriter 第四步:以socket对象得到输入流来构造相应的BufferedReader对象,该

  • 实现了基于TCP的Java Socket编程实例代码

    实现了基于TCP的Java Socket编程,功能很简单:客户端向服务器端输出一名话"connect",服务器端接收输出到控制台并向客户端输出一名话"Hello",客户端接收并输出. 1.服务器端 复制代码 代码如下: package javase.net.socket; import java.io.DataInputStream;  import java.io.DataOutputStream;  import java.io.IOException;  im

  • Linux下用C语言实现推箱子游戏

    前面有Linux的常用命令和vim文本编辑器还没有介绍,之后我会补上的. 今天来介绍如何用C语言写一个简单的小游戏,叫做"小老鼠推箱子".虽然游戏的编写过程不复杂,但是我觉得能够从中找到自己对于编程的不足和完善自己的编程思维是最重要的.游戏代码不多,所以直接写在一个c文件中.本人小白,有不足之处还望指教 游戏介绍 下图是游戏开始界面,$是小老鼠,#是墙,O是终点,当小老鼠把所有箱子推进终点就代表游戏通过. 游戏思维 游戏地图用一个二维数组去存储.数组中不同的值代表不同的对象(老鼠.墙.

随机推荐