操作系统:进程管理

一、利用 fork 创建一个子进程(复制进程映像):父进程用 fork 启动子进程, 然后父进程和子进程各自运行。
(1)代码:

#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
int main(){
    
    
pid_t pid; 
char *message;
int n;
printf("fork progra starting\n");
pid=fork(); 
switch(pid){
    
    
case -1: 
perror("fork failed");
exit(1);
case 0: 
message="child";
n=5;
break;
default: 
message="parent";
n=3;
break;
}
for(;n>0;n --) 
{
    
    
puts(message); 
sleep(1); 
}
exit(0);
}

(2)运行结果:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
二、等待一个进程:上面实验的结果较为混乱,让父进程调用 wait 函数等待子进程结束。
(1)代码:

#include <sys/types.h>
#include <sys/wait.h> 
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
int main(){
    
    
pid_t pid; 
char *message;
int n;
int exit_code;
printf("fork progra starting\n");
pid=fork(); 
switch(pid){
    
    
case -1:
perror("fork failed");
exit(1);
case 0: 
message="child";
n=5;
exit_code=37; 
break;
default: 
message="parent";
n=3;
exit_code=0;
break;
}
for(;n>0;n --) 
{
    
    
puts(message);
sleep(1);
}

if(pid!=0) {
    
     
int stat_val;
pid_t child_pid;
child_pid=wait(&stat_val);
printf("Child has finished: PID=%d\n",child_pid);
if(WIFEXITED(stat_val)) 
 printf("child exited with code %d\n", WEXITSTATUS(stat_val)); 
else
printf("child terminated abnormally\n");
}
exit(exit_code);
}

(2)运行结果:
在这里插入图片描述
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/m0_55726741/article/details/129240153