linux信号处理--通过发送信号控制进程

要求:

实现两个程序mysignal、mycontrl,
mycontrl给mysignal发送SIGINT信号,控制mysiganl是否在屏幕打印"hello,world"字符串.

//makefile

.SUFFIXES: .c .o
CC=gcc
SRCS1=mysignal.c
SRCS2=mycontrol.c

OBJS1=$(SRCS1:.c=.o)
OBJS2=$(SRCS2:.c=.o)
EXEC1=mysignal
EXEC2=mycontrol
all: $(OBJS1) $(OBJS2)
    $(CC)  -o $(EXEC1) $(OBJS1)
    $(CC)  -o $(EXEC2) $(OBJS2)
    @echo '-------------ok--------------'
.c.o:
    $(CC) -g  -o [email protected] -c $<
clean:
    rm -f $(OBJS1) $(OBJS2)
    rm -f core*

//mysignal.c

#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
int status = 0;//全局量,1-打印,0-不打印
void catch_Signal(int Sign)
{
    switch (Sign)
    {
    case SIGINT:
        if (status == 0)
        {
            status = 1;
        }
        else
        {
            status = 0;
        }
    }
}
int signal1(int signo, void(*func)(int))
{
    struct sigaction act, oact;
    act.sa_handler = func;
    sigemptyset(&act.sa_mask);
    act.sa_flags = 0;
    return sigaction(signo, &act, &oact);
}
int main(int arg, char *args[])
{
    signal1(SIGINT, catch_Signal);//捕捉SIGINT信号
    while (1)
    {
        if (status)//如果status为1,打印字符串”hello“
        {
            puts("hello, world");
        }
        sleep(1);
    }
    return 0;
}

//mycontrol.c

#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
int main(int arg, char *args[])
{
    if (arg < 2)//如果没有参数,main返回
    {
        return -1;
    } else
    {
        int pid = atoi(args[1]);
        kill(pid, SIGINT);//向指定的pid发送SIGINT信号
    }
    return 0;
}

运行效果:

时间: 2024-11-08 01:02:41

linux信号处理--通过发送信号控制进程的相关文章

20181203使用信号控制进程

使用信号控制进程 kill(只能跟PID或JOB ID),killall(name),pgrep,pkill,top给进程发送信号[[email protected] ~]# kill -l //列出所有支持的信号编号 信号名1) SIGHUP 重新加载配置 PID 不变2) SIGINT 键盘中断^C3) SIGQUIT 键盘退出9) SIGKILL 强制终止15) SIGTERM 终止(正常结束),缺省信号,允许去释放资源18) SIGCONT 继续19) SIGSTOP 停止20)SIGT

linux驱动的异步通知(kill_fasync,fasync)---- 驱动程序向应用程序发送信号

应用程序 [cpp] view plain copy #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <stdio.h> #include <poll.h> #include <signal.h> #include <sys/types.h> #include <unistd.h> #include <fcn

linux 信号处理 一

信号是Linux编程中非常重要的部分,本文将详细介绍信号机制的基本概念.Linux对信号机制的大致实现方法.如何使用信号,以及有关信号的几个系统调用. 信号机制是进程之间相互传递消息的一种方法,信号全称为软中断信号,也有人称作软中断.从它的命名可以看出,它的实质和使用很象中断.所以,信号可以说是进程控制的一部分. 一.信号的基本概念 本节先介绍信号的一些基本概念,然后给出一些基本的信号类型和信号对应的事件.基本概念对于理解和使用信号,对于理解信号机制都特别重要.下面就来看看什么是信号. 1.基本

Linux 进程间通信系列之 信号

信号(Signal) 信号是比较复杂的通信方式,用于通知接受进程有某种事件发生,除了用于进程间通信外,进程还可以发送信号给进程本身:Linux除了支持Unix早期信号语义函数sigal外,还支持语义符合Posix.1标准的信号函数sigaction(实际上,该函数是基于BSD的,BSD为了实现可靠信号机制,又能够统一对外接口,用sigaction函数重新实现了signal函数) 信号种类 每种信号类型都有对应的信号处理程序(也叫信号的操作),就好像每个中断都有一个中断服务例程一样.大多数信号的默

linux 信号处理 三

一.信号及信号来源 信号本质 信号是在软件层次上对中断机制的一种模拟,在原理上,一个进程收到一个信号与处理器收到一个中断请求可以说是一样的.信号是异步的,一个进程不必通过任何操作来等待信号的到达,事实上,进程也不知道信号到底什么时候到达. 信号是进程间通信机制中唯一的异步通信机制,可以看作是异步通知,通知接收信号的进程有哪些事情发生了.信号机制经过POSIX实时扩展后,功能更加强大,除了基本通知功能外,还可以传递附加信息. 信号来源 信号事件的发生有两个来源:硬件来源(比如我们按下了键盘或者其它

kill 发送消息给进程命令

功能: kill命令发送信号给进程. 格式: kill [-s signal|-p] [-q sigval] [-a] [--] pid... kill -l [signal] kill [-s <信息名称或编号>][程序] 或 kill [-l <信息编号>] 参数: OPTIONS pid... Specify the list of processes that kill should signal. Each pid can be one of five things: n

我使用过的Linux命令之kill - 终止进程/发送信号

用途说明 kill命令用于终止指定的进程(terminate a process),是Unix/Linux下进程管理的常用命令.通常,我们在需要终止某个或某些进程时,先使用ps/pidof/pstree/top等工具获取进程PID,然后使用kill命令来杀掉该进程.kill命令的另外一个用途就是向指定的进程或进程组发送信号(The  command kill sends the specified signal to the specified process or process group)

Linux 命令 - killall: 通过进程名向进程发送信号

命令格式 killall [-Z CONTEXT] [-u USER] [ -eIgiqrvw ] [ -SIGNAL ] NAME... killall -l, --list killall -V, --version 命令参数 -e, --exact 对于长名字,要求精确匹配.如果一个命令名的长度超过 15 字符,则可能不会用完整的名字.这种情况下,killall 会杀死名字匹配前 15 个字符的进程.使用 -e 选项,则会要求进程名字完全匹配. -I, --ignore-case 匹配进程

Linux 发送信号

使用kill命令 --在命令行执行kill命令.向指定进程发送信号. 使用kill函数 int kill(pid_t pid,int sig); --参数pid指定一个要杀死的进程,而sig是要发送的信号. //kill函数发送信号 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <errno.h> #include &