[C++]Linux之多进程运行代码框架
声明:如需引用或者摘抄本博文源码或者其文章的,请在显著处注明,来源于本博文/作者,以示尊重劳动成果,助力开源精神。也欢迎大家一起探讨,交流,以共同进步~ 0.0
多进程代码框架示例
/*
@url:http://www.cnblogs.com/johnnyzen/p/8022597.html
@author:Johnny Zen
@school:XiHua University
@contact:johnnyztsd@gmail.com or 1125418540@qq.com
@date:2017-12-11 13:08
@description:Linux下多进程代码框架[C编程]
@environment:Linux For Ubuntu 16.04/64
*/
#include<sys/types.h>
#include<signal.h>
int main(){
pid_t sub_a, sub_b, sub_c, sub_d;//4个子进程
while((sub_a = fork()) == -1);//在主进程下,创建子进程a
if(sub_a > 0){//在主进程中,且成功创建子进程a
while((sub_b = fork()) == -1); //在主进程下,创建子进程b
if(sub_b > 0){//在主进程中,且成功创建子进程b
while((sub_c = fork()) == -1); //在主进程下,创建子进程c
if(sub_c > 0){//在主进程中,且成功创建子进程c
while((sub_d = fork()) == -1); //在主进程下,创建子进程d
if(sub_d > 0){//在主进程中,且成功创建子进程d
printf("在主进程中,且已成功创建子进程a/b/c/d:[Current PID:%d; Parent PID:%d;sub_a pid:%d;sub_b pid:%d;sub_c pid:%d;sub_d pid:%d;]\n", getpid(), getppid(), sub_a, sub_b, sub_c, sub_d);
} else {//在子进程d中
printf("在子进程d中:[Current PID:%d; Parent PID:%d;sub_d pid:%d]\n", getpid(), getppid(), sub_d);
}
} else {//在子进程c中
printf("在子进程c中:[Current PID:%d; Parent PID:%d;sub_c pid:%d]\n", getpid(), getppid(), sub_c);
}
} else {//在子进程b中
printf("在子进程b中:[Current PID:%d; Parent PID:%d;sub_b pid:%d]\n", getpid(), getppid(), sub_b);
}
} else { //在子进程a中
printf("在子进程a中:[Current PID:%d; Parent PID:%d;sub_a pid:%d]\n", getpid(), getppid(), sub_a);
}
return 0;
}
/* 运行结果:
在子进程a中:[Current PID:4605; Parent PID:4604;sub_a pid:0]
在子进程b中:[Current PID:4606; Parent PID:4604;sub_b pid:0]
在主进程中,且已成功创建子进程a/b/c/d:[Current PID:4604; Parent PID:4189;sub_a pid:4605;sub_b pid:4606;sub_c pid:4607;sub_d pid:4608;]
在子进程c中:[Current PID:4607; Parent PID:4604;sub_c pid:0]
在子进程d中:[Current PID:4608; Parent PID:1520;sub_d pid:0]
*/
运行效果

另附一份自己的进程相关实验源码
方便道友们学习之用
#include <stdio.h>
#include <signal.h>
#include <unistd.h> void waiting(),stop(),alarming();
int wait_mark; void main()
{
int p1,p2;//声明两个子进程变量
if(p1=fork())//创建子进程1
{
if(p2=fork())//创建子进程2
{
wait_mark=1;//等待标记
signal(SIGINT,stop);//捕捉中断信号,执行stop
signal(SIGALRM,alarming);//捕捉SIGALRM信号,执行alarming
waiting();//等待软中断信号,5s内按【DEL】发送中断信号SIGINT,否则会向当前进行发送SIGALRM信号。
kill(p1,16);//向子程序p1发送信号16
kill(p2,17);//向子程序p2发送信号17
wait(0);//等待第一个子进程终止
wait(0);//等待第二个子进程终止
printf("parent process is killed!\n");//输出父进程终止
exit(0);//正常终止父进程
}
else
{
wait_mark=1;//等待标记
signal(17,stop);//子进程p2接收到信号后执行stop
signal( SIGINT,SIG_IGN);//忽略中断信号SIGINT对本进程的影响
while(wait_mark!=0);
lockf(1,1,0);//锁定屏幕,不让其他进程输出
printf("children process2 is killed by parent\n");//输出进程2被父进程终止
lockf(1,0,0);//解锁
exit(0);//正常终止进程2
}
}
else
{
wait_mark=1;//等待标记
signal(16,stop);//子进程p2接收到信号后执行stop
signal(SIGINT,SIG_IGN);//忽略中断信号SIGINT对本进程的影响
while(wait_mark!=0)
lockf(1,1,0);//锁定屏幕,不让其他进程输出
printf("children process1 is killed by parent\n");//输出进程1被父进程终止
lockf(1,0,0);//解锁
exit(0);//正常终止进程1
}
}
void waiting()
{
sleep(5);//等待5S
if(wait_mark!=0)
kill(getpid(),SIGALRM);//对当前进程发送SIFALRM信号
}
void alarming()
{
wait_mark=0;
}
void stop()
{
wait_mark=0;
}
参考文献
原创。
[C++]Linux之多进程运行代码框架的更多相关文章
- Virtio:针对 Linux 的 I/O 虚拟化框架
Virtio:针对 Linux 的 I/O 虚拟化框架 --http://www.ibm.com/developerworks/cn/linux/l-virtio/#ibm-pcon 使用 KVM 和 ...
- linux下多进程的调试
linux下多进程的调试: (1)follow-fork-mode set follow-fork-mode [parent | child] ---- fork之后选择调试父进 ...
- [转帖]Windows和Linux对决(多进程多线程)
Windows和Linux对决(多进程多线程) https://blog.csdn.net/world_2015/article/details/44920467 太长了 还没看完.. 还是没太理解好 ...
- 自适应大邻域搜索代码系列之(1) - 使用ALNS代码框架求解TSP问题
前言 上次出了邻域搜索的各种概念科普,尤其是LNS和ALNS的具体过程更是描述得一清二楚.不知道你萌都懂了吗?小编相信大家早就get到啦.不过有个别不愿意透露姓名的热心网友表示上次没有代码,遂不过瘾啊 ...
- linux 下 多进程与多线程
[Linux]多进程与多线程之间的区别 http://blog.csdn.net/byrsongqq/article/details/6339240 网络编程中设计并发服务器,使用多进程与多线程 ,请 ...
- linux设备驱动程序--串行通信驱动框架分析
linux 串行通信接口驱动框架 在学习linux内核驱动时,不论是看linux相关的书籍,又或者是直接看linux的源码,总是能在linux中看到各种各样的框架,linux内核极其庞杂,linux各 ...
- 在Linux系统下运行微信Web开发者工具
微信Web开发者工具只有window版本和mac版本,如果想要在Linux系统下运行微信Web开发者工具,需要花费很大周折. 注:带 * 的步骤或文件为不确定是否管用的步骤或文件.本人系统为Linux ...
- linux进程后台运行的几种方法
转载:http://hi.baidu.com/ntuxmzvdpzbnuxq/item/79131b93f606a348f0421562 我 们经常会碰到这样的问题,用 telnet/ssh 登录了远 ...
- linux下编译运行驱动
linux下编译运行驱动 嵌入式linux下设备驱动的运行和linux x86 pc下运行设备驱动是类似的,由于手头没有嵌入式linux设备,先在vmware上的linux上学习驱动开发. 按照如下方 ...
随机推荐
- Java 多线程篇
先举个例子 计算机的核心是CPU,它承担了计算机所有计算任务,可以把它理解为像一个工厂,时刻在运行. 假定工厂有一个电力系统,工厂有很多车间,一次只能供给一个车间使用,也就是说一个车间开工的时候,其他 ...
- (二叉树 bfs) leetcode 199. Binary Tree Right Side View
Given a binary tree, imagine yourself standing on the right side of it, return the values of the nod ...
- python: 反射机制;
import comma def run(): inp = input('请输入要调用的函数').strip(); if hasattr(comma,inp): fun = getattr(comma ...
- 1.1实战项目:电影周周看V1(初识小程序)
第一小程序的实战项目: 覆盖的小程序技术: 讲解方式: 学习方法:
- ttribute "xmlns" was already specified for element "web-app".
今天导入了,一个javaweb项目,当自己对项目进行重命名的时候时候,但是web.xml直接爆出来一个"ttribute "xmlns" was already spec ...
- CSS样式链接和文字常用属性
行内: <div style="color:red;"></div> 内嵌<style>div{background-color:red;}&l ...
- RocketMQ_问题_启动报错,修改堆内存大小
1.启动broker报错 虚拟机内存小,导致虚拟机中的JVM内存小,进而在启动broker时分配JVM内存遇到问题 查询网上得知,查看/usr/local/rocketmq-all-4.3.0/dis ...
- SQL语法基础之CREATE语句
SQL语法基础之CREATE语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查看帮助信息 1>.使用“?”来查看MySQL命令的帮助信息 mysql> ? CR ...
- 【2】【leetcode-105,106】 从前序与中序遍历序列构造二叉树,从中序与后序遍历序列构造二叉树
105. 从前序与中序遍历序列构造二叉树 (没思路,典型记住思路好做) 根据一棵树的前序遍历与中序遍历构造二叉树. 注意:你可以假设树中没有重复的元素. 例如,给出 前序遍历 preorder = [ ...
- HDU 6425(羽毛球组合 **)
题意是说有四种同学,没有球拍没有球的( a ),只有球拍的( b ),只有球的( c ),既有球拍又有球的( d ):现在要去打羽毛球,每个人都可以选择去或者不去,问有多少种无法打羽毛球的情况. 无法 ...