【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};
    //数组形式
    //返回值类型 (* 数组名[数组大小])(函数的形参表) = {};
}
相关推荐
Johny_Zhao5 小时前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
董董灿是个攻城狮7 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
怒放吧德德8 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆10 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌12 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊13 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang14 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
AI软著研究员14 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish14 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
Ray Liang15 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计