【Linux】多进程任务模块

创建多个进程,同时完成任务

task.c

cs 复制代码
#include <sys/types.h>
#include <unistd.h>
#include<stdio.h>
#include <sys/wait.h>
int create_process_tasks(Task_fun_t tasks[],int tsak_cnt)
{
    pid_t pid;
    int i = 0;
    for(i = 0;i < 4;i++)
    {
        pid = fork();
        if(pid > 0)
        {

        }
        else if(0 == pid)
        {
            break;
        }
    }
    if(pid > 0)
    {
        return 0;
    }
    else if(0 == pid)
    {
        tasks[i]();
    }
    else
    {
        return -1;
    }
    return 0;
}


void destroy_task(int tasks_cnt)
{
    int i;
    for(i = 0;i < tasks_cnt;i++)
    {
        wait(NULL);
    }
}

task.h

cs 复制代码
#ifndef __TASK_H__
#define __TASK_H__

typedef void(*Task_fun_t)(void);//将void (*)(void)函数指针重命名为---->Tsak_fun_t

extern int create_process_tasks(Task_fun_t tasks[],int tsak_cnt);
extern void destroy_task(int task_cnt);
#endif

main.c

cs 复制代码
#include<stdio.h>
#include"task.h"
int main(int argc, char const *argv[])
{
    //void (*pfun_arg[])(void) = {main_ctl, get_cmd, exec_cmd, get_pic, send_pic};


    Task_fun_t tasks[] = {main_ctl,get_cmd,exec_cmd,get_pic,send_pic};
    //函数指针数组里装的是调用者需要执行任务的函数的函数名
    //调用者可自定义函数所需要实现的功能
    create_process_tasks(tasks,sizeof(tasks) / sizeof(tasks[0]));//创建多线程
    destroy_task(sizeof(tasks,sizeof(tasks[0])));//回收线程
    return 0;
}

函数指针数组

cs 复制代码
#include <stdio.h>
 
void bubbleSort(int arr[], int size);
void selectionSort(int arr[], int size);
void insertionSort(int arr[], int size);

int main()
{
    void (*sortFuncs[3])(int[], int) = {bubbleSort, selectionSort, insertionSort};
    //数组形式
    //返回值类型 (* 数组名[数组大小])(函数的形参表) = {};
}
相关推荐
py有趣1 小时前
LeetCode算法学习之两数之和 II - 输入有序数组
学习·算法·leetcode
夏鹏今天学习了吗1 小时前
【LeetCode热题100(62/100)】搜索二维矩阵
算法·leetcode·矩阵
工业甲酰苯胺2 小时前
实现 json path 来评估函数式解析器的损耗
java·前端·json
老前端的功夫2 小时前
Web应用的永生之术:PWA落地与实践深度指南
java·开发语言·前端·javascript·css·node.js
@forever@2 小时前
【JAVA】LinkedList与链表
java·python·链表
安审若无3 小时前
图数据库neoj4安装部署使用
linux·运维·数据库
LilySesy3 小时前
ABAP+WHERE字段长度不一致报错解决
java·前端·javascript·bug·sap·abap·alv
六件套是我3 小时前
redission实现延时队列
android·java·servlet
吃着火锅x唱着歌3 小时前
LeetCode 1128.等价多米诺骨牌对的数量
算法·leetcode·职场和发展
做运维的阿瑞3 小时前
CentOS DNS故障排查完整解决方案:从症状到根因的系统化诊断
linux·运维·centos