简易版的进程池

2024-06-22 05:28
文章标签 进程 简易版

本文主要是介绍简易版的进程池,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.使用匿名管道实现 进程池

#pragma oncetypedef void(*task_t)();void task1()
{cout << "游戏 刷新日志" << endl;
}void task2()
{cout << "游戏 刷新野区" << endl;
}
void task3()
{cout << "游戏 检测软件是否更新,如果需要,就提示用户" << endl;
}
void task4()
{cout << "游戏 用户释放技能,更新用户的HP和MP"<<endl;
}
void Loadtask(vector<task_t> *tasks)
{tasks->push_back(task1);tasks->push_back(task2);tasks->push_back(task3);tasks->push_back(task4);
}//以上是头文件//以下是程序;
//类似于内存池,每次使用都不再向系统申请进程,而是提前储备进程;
#include<cstdlib>
#include<cassert>
#include<time.h>
#include<sys/wait.h>
#include<sys/stat.h>
#include<iostream>
#include<vector>
#include<string>
#include<unistd.h>using namespace std;
#include"main.h"
const int processnum = 5;//子进程数量=5
vector<task_t> tasks;  //任务列表,全局变量//先描述
class channel
{
public:channel(int cmdfd ,pid_t slaverid,const string &processname):_cmdfd(cmdfd),_slaverid(slaverid),_processname(processname){}
public:int _cmdfd;	//发送任务的文件描述符pid_t _slaverid; //子进程的pidstring _processname;//子进程的名字——方便我们打印日志;
};void slaver()
{//read(0);//直接从标准输入读while (true){int cmdcode = 0;int n = read(0,&cmdcode,sizeof(int));//如果父进程不给子进程发任务?就会阻塞等待;if (n == sizeof(int)){//执行cmdcode 对应的任务列表;cout << getpid() << ":cmdcode:" << cmdcode << endl;//查看父进程给子进程派发的任务码;if (cmdcode > 0 && cmdcode < tasks.size()) //满足条件运行函数;tasks[cmdcode]();}if (n == 0){break;}}
}
//函数传参,需要输入型,输出型,输入输出型参数;
//输入:const &: const引用
//输出:用指针
//输入输出:&引用
void InitProcessPool(vector<channel>* channels)
{//1.初始化for (int i = 0; i < processnum; i++){int pipefd[2];//临时空间;int n = pipe(pipefd);assert(!n);//判断是否成功;(void)n;pid_t id = fork();if (id == 0)//子进程读{close(pipefd[1]);dup2(pipefd[0], 0);//重定向,从标准输入中读close(pipefd[0]);slaver();//执行相对应的任务;cout << "process: " << getpid() << "quit" << endl;//打印子进程pid;退出进程;exit(0);}//父进程写入close(pipefd[0]);//添加channel字段;string name = "process-" + to_string(i);channels->push_back(channel(pipefd[1], id, name));}
}
void Debug(const vector<channel> &channels)
{//testfor (const auto& c : channels){cout << c._cmdfd << " " << c._slaverid << " " << c._processname << endl;}
}
void Menu()											//菜单
{cout << "1.刷新日志" << endl;cout << "2.刷新野怪" << endl;cout << "3.检测更新" << endl;cout << "4.更新状态" << endl;cout << "0.退出游戏" << endl;
}
//控制子进程
void ctrlSlaver(const vector<channel>& channels)
{int which = 0;//int cnt = 5;while(true){int select = 0;Menu();                              //手动控制cout << "please Enter@" << endl;cin >> select;if (select <= 0 || select >= 5) break;//select >0 &&select<5//1.选择任务//int cmdcode = rand() % tasks.size();//创造一个随机数,当作任务;int cmdcode = select-1;//2.选择进程(负载均衡:不可以一直给某个进程派发任务,其他进程都闲着,要均衡发展这个叫做负载均衡)1.使用随机数  2.轮转l来实现负载均衡//int processpos = rand() % channels.size();						//随机数//cout << "father say:" << "cmdcode:" << cmdcode << "already send to" << channels[processpos]._slaverid << endl;cout << "father say:" << "cmdcode:" << cmdcode << "already send to" << channels[which]._slaverid << endl;//轮转//3.发送任务//write(channels[processpos]._cmdfd, &cmdcode, sizeof(cmdcode));      //随机数版本write(channels[which]._cmdfd, &cmdcode, sizeof(cmdcode));			  //轮转which++;which %= channels.size();//cnt--;//sleep(1);}
}
void QuitProcess(const vector<channel> &channels)						//退出进程
{for (const auto& c : channels){close(c._cmdfd);}//sleep(5);for (const auto& c : channels) waitpid(c._slaverid, nullptr, 0);   //等待退出//sleep(5);
}int main()
{Loadtask(&tasks);							//加载任务参数;srand(time(nullptr) ^ getpid() ^ 1023);		//种一个随机数种子//再组织vector<channel> channels;//初始化-------bug?————画图就可以看出来,推荐画一下图!!!答:文件描述符随着创建子进程递增;InitProcessPool(&channels);					//初始化Debug(channels);							//测试//2.开始控制子进程ctrlSlaver(channels);						//控制子进程//3.清理收尾QuitProcess(channels);return 0;
}

这篇关于简易版的进程池的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1083410

相关文章

Linux中的进程间通信之匿名管道解读

《Linux中的进程间通信之匿名管道解读》:本文主要介绍Linux中的进程间通信之匿名管道解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基本概念二、管道1、温故知新2、实现方式3、匿名管道(一)管道中的四种情况(二)管道的特性总结一、基本概念我们知道多

Linux进程终止的N种方式详解

《Linux进程终止的N种方式详解》进程终止是操作系统中,进程的一个重要阶段,他标志着进程生命周期的结束,下面小编为大家整理了一些常见的Linux进程终止方式,大家可以根据需求选择... 目录前言一、进程终止的概念二、进程终止的场景三、进程终止的实现3.1 程序退出码3.2 运行完毕结果正常3.3 运行完毕

Windows命令之tasklist命令用法详解(Windows查看进程)

《Windows命令之tasklist命令用法详解(Windows查看进程)》tasklist命令显示本地计算机或远程计算机上当前正在运行的进程列表,命令结合筛选器一起使用,可以按照我们的需求进行过滤... 目录命令帮助1、基本使用2、执行原理2.1、tasklist命令无法使用3、筛选器3.1、根据PID

linux本机进程间通信之UDS详解

《linux本机进程间通信之UDS详解》文章介绍了Unix域套接字(UDS)的使用方法,这是一种在同一台主机上不同进程间通信的方式,UDS支持三种套接字类型:SOCK_STREAM、SOCK_DGRA... 目录基础概念本机进程间通信socket实现AF_INET数据收发示意图AF_Unix数据收发流程图A

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程

Linux之进程状态&&进程优先级详解

《Linux之进程状态&&进程优先级详解》文章介绍了操作系统中进程的状态,包括运行状态、阻塞状态和挂起状态,并详细解释了Linux下进程的具体状态及其管理,此外,文章还讨论了进程的优先级、查看和修改进... 目录一、操作系统的进程状态1.1运行状态1.2阻塞状态1.3挂起二、linux下具体的状态三、进程的

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa