【Linux程序设计】之进程间的通信
这个系列的博客贴的都是我大二的时候学习Linux系统高级编程时的一些实验程序,都挺简单的。
实验题目:Linux环境下的进程间通信
实验目的:熟悉进程通信中信号概念及信号处理;掌握进程间的管道通信编程;了解进程间的内存共享编程。
实验内容:
一、信号
设计程序,满足如下要求:
1、编程程序:每隔1秒显示“running….”一次,显示8次后,程序结束。应用函数alarm,在程序开始运行5秒后发送信号SIGALRM,并实现:1)程序接收到SIGALRM信号就被终止;2)自定义信号处理函数,在程序接收到SIGALRM信号后,循环显示三次“handling SIGALRM”。
- #include<stdio.h>
- #include<unistd.h>
- #include<signal.h>
- #include<stdlib.h>
- int main()
- {
- alarm();
- int i;
- for(i=;i<=;i++)
- {
- printf("running…\n");
- sleep();
- }
- return ;
- }
- #include<stdio.h>
- #include<unistd.h>
- #include<signal.h>
- #include<stdlib.h>
- void fun()
- {
- int i=;
- for(i=;i<=;i++)
- {
- printf("handling SIGALRM \n");
- }
- }
- int main()
- {
- (void)signal(SIGALRM,fun);
- alarm();
- int i;
- for(i=;i<=;i++)
- {
- printf("running…\n");
- sleep();
- }
- return ;
- }
2、设计一个程序,要求用户进程创建一个子进程,子进程发送SIGSTOP将自身挂起,父进程向子进程发出SIGKILL信号,子进程收到此信号,结束子进程的运行。
- #include<stdio.h>
- #include<unistd.h>
- #include<stdlib.h>
- #include<signal.h>
- int main()
- {
- pid_t pid;
- pid=fork();
- int ret;
- if(pid <)
- {
- printf("Error Exit!\n");
- exit();
- }
- else if(pid==)
- {
- raise(SIGSTOP);
- exit();
- }
- else
- {
- printf("子进程的进程号是:%d\n",pid);
- if(waitpid(pid,NULL,WNOHANG)==)
- {
- if(ret=kill(pid,SIGKILL)==)
- {
- ptintf("fun kill's return is %d,pid is%d\n",ret,pid);
- }
- }
- }
- return ;
- }
3、设计一个程序,要求程序运行后进入无限循环,要求主程序运行时,即使用户按下中断键(Ctrl+Z和Ctrl+\),也不能影响正在运行的程序,即让信号处于阻塞状态,当主体程序运行完毕后才进入自定义信号处理函数,当用户再次按下中断键(Ctrl+Z和Ctrl+\)后,结束程序运行。
- #include<stdio.h>
- #include<unistd.h>
- #include<signal.h>
- #include<sys/types.h>
- #include<stdlib.h>
- void fun_z()
- {
- printf("you press Ctrl+z\n");
- printf("Ctrl + z is useable now!\n");
- signal(SIGTSTP,SIG_DFL);
- }
- void fun_d()
- {
- printf("you press 'Ctrl+\' \n");
- printf("Ctrl + d is useable now!\n");
- signal(SIGQUIT,SIG_DFL);
- }
- int main()
- {
- int i;
- sigset_t set,pendset;
- struct sigaction action;
- signal(SIGTSTP,fun_z);
- signal(SIGQUIT,fun_d);
- if(sigemptyset(&set)<)
- perror("init sign error!");
- if(sigaddset(&set,SIGTSTP)<)
- perror("add ctrl+z error!\n");
- if(sigaddset(&set,SIGQUIT)<)
- perror("ass 'ctrl+\' error!\n");
- while()
- {
- printf("Ctrl +z and 'Ctrl +\' is zuse!\n");
- sleep();
- }
- return ;
- }
二、管道
1、设计一个程序,要求创建一个管道,复制进程,父进程往管道中写入字符串“how are you!”,子进程从管道中读取并输入字符串“how are you!”。
- #include<stdio.h>
- #include<stdlib.h>
- #include<sys/types.h>
- #include<sys/wait.h>
- #include<unistd.h>
- #include<string.h>
- int main()
- {
- pid_t result;
- int n;
- int pipe_fd[];
- char buf1[],buf2[];
- memset(buf1,,sizeof(buf1));
- if(pipe(pipe_fd)<)
- {
- printf("error!\n");
- return -;
- }
- result=fork();
- if(result<)
- {
- printf("error!\n");
- exit();
- }
- else if(result==)
- {
- close(pipe_fd[]);
- if((n =read(pipe_fd[],buf1,))>)
- {
- printf("child read %d char,char is %s\n",n,buf1);
- close(pipe_fd[]);
- exit();
- }
- }
- else
- {
- close(pipe_fd[]);
- printf("please input pipe word \n");
- fgets(buf2,sizeof(buf2),stdin);
- if(write(pipe_fd[],buf2,strlen(buf2))!=-)
- printf("parent write to child is: %s\n",buf2);
- close(pipe_fd[]);
- waitpid(result,NULL,);
- exit();
- }
- return ;
- }
2、设计一个程序,要求用popen创建管道,实现“rpm -qa | grep nfs”的功能。
3、设计一个程序,要求创建一个管道PIPE,复制进程,父进程运行命令“ls –l”,把运行结果写入管道,子进程从管道中读取“ls -l”的结果,把读出的作为输入接着运行“grep .c”。
三、共享内存
1、设计一个程序,要求创建进程,父子进程通过匿名映射实现共享内存。
【Linux程序设计】之进程间的通信的更多相关文章
- Linux c 管道文件-进程间的通信 mkfifo、pipe
管道文件: 1. 创建管道mkfifo(命名管道) #include<sys/stat.h> int mkfifo( const char *pathname, mode_ ...
- Linux进程间的通信
一.管道 管道是Linux支持的最初Unix IPC形式之一,具有以下特点: A. 管道是半双工的,数据只能向一个方向流动: B. 需要双工通信时,需要建立起两个管道: C. 只能用于父子进程或者兄弟 ...
- c++ 网络编程(三) LINUX/windows 进程间的通信原理与实现代码 基于多进程的服务端实现
原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/9613027.html 锲子:进程与线程是什么,他们的区别在哪里: 1 进程概念 进程是程序的一 ...
- PHP与Linux进程间的通信
进程间通信预计是公司考察应届毕业生的必考点(嵌入式行业).当然非常多公司考的是算法. 不查阅资料,我脑子里能想到的 [1] 管道, (有名.无名) [2] 父子进程 [3] System V (消息队 ...
- c 进程间的通信
在上篇讲解了如何创建和调用进程 c 进程和系统调用 这篇文章就专门讲讲进程通信的问题 先来看一段下边的代码,这段代码的作用是根据关键字调用一个Python程序来检索RSS源,然后打开那个URL #in ...
- Linux 线程与进程,以及通信
http://blog.chinaunix.net/uid-25324849-id-3110075.html 部分转自:http://blog.chinaunix.net/uid-20620288-i ...
- Nginx学习——Nginx进程间的通信
nginx进程间的通信 进程间消息传递 共享内存 共享内存还是Linux下提供的最主要的进程间通信方式,它通过mmap和shmget系统调用在内存中创建了一块连续的线性地址空间,而通过munmap或者 ...
- swoole进程间如何通信
Swoole进程间通信的方式 管道pipe 管道用于进程之间的数据交互,Linux系统本身提供了pipe函数用于创建一个半双工通信管道.半双工的通信方式中数据只能单向流动(一端只读一端只写),只能在具 ...
- Android进程间的通信之AIDL
Android服务被设计用来执行很多操作,比如说,可以执行运行时间长的耗时操作,比较耗时的网络操作,甚至是在一个单独进程中的永不会结束的操作.实现这些操作之一是通过Android接口定义语言(AIDL ...
- Android进程间的通信之Messenger
Android进程间的通信方式可以通过以下两种方式完成: Android接口定义语言(AIDL) 使用Messenger绑定服务 本文我们将学习使用Messenger绑定服务的方式进行进程间的通信. ...
随机推荐
- hdu 1541 Stars
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1541 思路:要求求出不同等级的星星的个数,开始怎么也想不到用树状数组,看完某些大神的博客之后才用树状数 ...
- JavaScript基础——处理字符串
String对象是迄今为止在JavaScript中最常用的对象.在你定义一个字符串数据类型的变量的任何时候,JavaScript就自定为你创建一个String对象.例如: var myStr = &q ...
- Lattice 的 DDR IP核使用调试笔记之DDR 的 仿真
—— 远航路上ing 整理于 博客园.转载请标明出处. 在上节建立完工程之后,要想明确DDR IP的使用细节,最好是做仿真.然后参考仿真来控制IP 核. 仿真的建立: 1.在IP核内的以下路径找到以下 ...
- Android -- java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available
使用Bundle 的getParcelableArray 出现了以下错误: Class not found when unmarshallingjava.lang.ClassNotFoundExcep ...
- 《CLR via C#》读书笔记(6)类型和成员基础
6.1 类型的各种成员 在一个类型中,可以定义0个或者多个以下种类的成员: 常量 常量是在编译时设置其值并且永远不能更改其值的字段.使用常量可以为特殊值提供有意义的名称以代替数字文本,以使代码变得更容 ...
- Qt Designer怎样加入资源文件
Qt Designer中如果在设计UI界面的时候要加入一些图素,图标等资源的时候是不能直接添加进去的,需要在Qt开发目录下编写QRC文件 qrc文件格式如下: <RCC> <qres ...
- postgresql设置默认的search_path
-- Use this to show the current search_path -- Should return: "$user",public SHOW search_p ...
- bootstrap表单带验证
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8& ...
- hdu 1404 找sg ***
HDU 1404 Digital Deletions 一串由0~9组成的数字,可以进行两个操作:1.把其中一个数变为比它小的数:2.把其中一个数字0及其右边的所以数字删除. 两人轮流进行操作,最后把 ...
- [Tools] maven-eclipse安装及配置
[背景] 买了个surface,带到公司当做开发机器来用,各种环境都需要重新安装,写个笔记记录下maven安装步骤,虽然很简单,但是我这脑子,容易忘记,写下来以备用 [开工] 安装Maven 访问 M ...