博客
关于我
操作系统实验之进程管理
阅读量:569 次
发布时间:2019-03-09

本文共 1683 字,大约阅读时间需要 5 分钟。

目录

前言

一、实验要求

掌握子进程的创建、父子进程的通信及其原理。
二、实验内容
1.熟悉 Linux 环境基本使用命令,熟悉使用 vi、gdb、gcc 等编程工具或软件
2.使用系统调用 fork()创建两个子进程,父进程、子进程并发执行,输出
并发执行的消息,如:
------------------------------------------
父进程正在执行……
子进程 1 正在执行…….
子进程 2 正在执行…
------------------------------------------
一段时间后,父进程杀死子进程,然后结束自己的进程,分别显示:
------------------------------------------
子进程 1 被父进程杀死
子进程 2 被父进程杀死
父进程结束
------------------------------------------

代码

t.c 文件代码如下

#include 
#include
#include
#include
int main(){ int pid; printf("---------------------\n"); printf("父进程正在执行……\n"); pid=fork();//父进程A生成子进程1 if(pid==0){ //子进程1执行 printf("子进程1正在执行……\n"); sleep(2); sleep(3);//等待一段时间 printf("---------------------\n"); printf("子进程1被父进程杀死\n"); exit(0); } if(pid>0){ int pid1=fork();//父进程A生成子进程2 if(pid1==0){ //子进程2执行 printf("子进程2正在执行……\n"); sleep(2); sleep(3);//等待一段时间 printf("子进程2被父进程杀死\n"); exit(0); } if(pid1>0){ sleep(1);//父进程A休眠一秒 printf("---------------------\n"); printf("一段时间后\n"); sleep(3);//等待一段时间 sleep(2); printf("父进程结束\n"); printf("---------------------\n"); exit(0); } } return 0;}

运行结果

在这里插入图片描述

代码解释

if 判断语句

详见下面文章

sleep() 休眠函数

更新中

转载地址:http://qtlpz.baihongyu.com/

你可能感兴趣的文章
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
mysql problems
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>