linux 进程管理实验.pptVIP

  • 11
  • 0
  • 约6.85千字
  • 约 30页
  • 2019-05-05 发布于江西
  • 举报
第四章 进程管理实验 4.1 实验目的 一、加深对进程概念的理解,明确进程和程序的区别 二.进一步认识并发执行的实质 三.分析进程争用资源的现象,学习解决进程互斥的方法 四.了解Linux系统中进程通信的基本原理 4.2 准备知识 4.2.1 基本概念 进程的概念 进程与程序的区别 并发执行的概念 进程互斥的概念 进程通信的基本原理 4.2.2 系统调用 图4-1 系统调用的参数表方式 4.2.3 相关函数 一.fork()函数:用于创建一个新进程(子进程) int fork(); pid = fork(); if(pid 0) { printf(fork error\n); exit(0);} if(pid == 0) { printf(The child process is running now!\n); exit(0);} if(pid 0) { printf(The parent process is running now!\n); exit(0);} 图3-2 父进程和子进程的内存映像 二.wait( )函数:用来控制父进程与子进程的同步。 #include sys/type.h #include sys/wait.h (pid_t) wait(int*statloc); 三.exit( )函数:进程结束最常调用的函数 #include stdio.h void exit(int status); 四.kill( )函数:用于删除执行中的程序或者任务 kill(int PID,int IID); 五.signal( )函数 signal()函数是允许调用进程控制软中断信号的处理 #include signal.h int sig; void (*func)(); signal(sig,function); 六.pipe( )函数 pipe()函数用于创建一个管道。 其调用格式为: #include unistd.h pipe(int fp[2]); 4.3.1 编制实现软中断通信的程序 Child process 1 is killed by parent !! Child process 2 is killed by parent !! Parent process is killed!! 多运行几次编写的程序,简略分析出现不同结果的原因。 4.3.2 编制实现进程的管道通信的程序 使用系统调用pipe()建立一条管道线,两个子进程分别向管道写一句话: Child process 1 is sending a message! Child process 2 is sending a message! 而父进程则从管道中读出来自于两个子进程的信息,显示在屏幕上。 要求:父进程先接收子进程P1发来的消息,然后再接收子进程P2发来的消息。 4.4 实验指导 4.4.1 进程的软中断通信 附:算法流程图、源代码、运行结果 4.4.2 进程的管道通信 附:算法流程图、源代码、运行结果 4.4.1 进程的软中断通信 参考程序源代码: #include stdio.h #include signal.h #include unistd.h #include sys/types.h 图4-3 软中断通信程序流程图 int wait_flag; void stop( ); main( ) { int pid1, pid2; // 定义两个进程号变量 signal(3,stop); // 或者 signal(14,stop); while((pid1 = fork( )) == -1); // 若创建子进程1不成功,则空循环 if(pid1 0) { // 子进程创建成功,pid1为进程号 while((pid2 = fork( )) == -1); // 创建子进程2 if(pid2

文档评论(0)

1亿VIP精品文档

相关文档