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

你可能感兴趣的文章
Netty原理分析及实战(四)-客户端与服务端双向通信
查看>>
Netty和Tomcat的区别已经性能对比
查看>>
Netty学习总结(5)——Netty之TCP粘包/拆包问题的解决之道
查看>>
Netty客户端断线重连实现及问题思考
查看>>
Netty工作笔记0006---NIO的Buffer说明
查看>>
Netty工作笔记0007---NIO的三大核心组件关系
查看>>
Netty工作笔记0011---Channel应用案例2
查看>>
Netty工作笔记0013---Channel应用案例4Copy图片
查看>>
Netty工作笔记0014---Buffer类型化和只读
查看>>
Netty工作笔记0020---Selectionkey在NIO体系
查看>>
Vue踩坑笔记 - 关于vue静态资源引入的问题
查看>>
Netty工作笔记0024---SelectionKey API
查看>>
Netty工作笔记0025---SocketChannel API
查看>>
Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
查看>>
Netty工作笔记0028---NIO 网络编程应用--群聊系统3--客户端编写1
查看>>
Netty工作笔记0034---Netty架构设计--线程模型
查看>>
Netty工作笔记0050---Netty核心模块1
查看>>
Netty工作笔记0057---Netty群聊系统服务端
查看>>
Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
查看>>
Netty工作笔记0063---WebSocket长连接开发2
查看>>