博客
关于我
操作系统实验之进程管理
阅读量: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/

你可能感兴趣的文章
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>