uloop_process
uloop_process 是 Libubox 提供的一个进程管理工具,它并不会帮你创建进程,它主要用来等待子进程工作的结束,然后调用自定义的回调函数,所以一般需要配合
fork一起使用。
uloop_process主要数据结构
struct list_head processes
static struct list_head processes = LIST_HEAD_INIT(processes);
processes是一个全局链表,用于管理多个struct uloop_process.
struct uloop_process
struct uloop_process
{
struct list_head list;
bool pending;
uloop_process_handler cb;
pid_t pid;
};
struct uloop_process用来描述一个子进程,其中:
- list 用于将
struct uloop_process结构加入全局processes链表 - pending标志此进程是否需要挂起(初始化时此参数务必置0)
- cb是此进程运行结束后的回调函数
- pid是进程ID(通常=fork()的返回值)
uloop_process_handler
typedef void (*uloop_process_handler)(struct uloop_process *c, int ret);
uloop_process_handler是子进程退出后会触发调用此回调函数(不是子进程自己调用,是运行uloop_run的进程会去调用),其中子进程的一些退出状态码可以通过参数ret获取。
如果子进程使用exit(150);函数退出,那这里的ret就是150.
更多有关进程状态码的信息参考这位大佬的文章:wait/waitpid 的 status 参数
uloop_process主要函数
int uloop_process_add(struct uloop_process *p);
int uloop_process_delete

uloop_process是Libubox中的进程管理工具,用于等待并处理子进程的结束。它包括全局链表`processes`、结构体`uloop_process`和回调函数`uloop_process_handler`。`uloop_process`结构体包含子进程信息,如回调函数和PID。`uloop_process_handler`在子进程结束时调用。主要函数有`uloop_process_add()`和`uloop_process_delete()`,分别用于添加和删除子进程。`uloop_handle_processes()`内部处理子进程结束,并调用回调函数。使用示例展示了如何创建子进程,添加到uloop管理,并在子进程结束时调用回调函数。
最低0.47元/天 解锁文章
2144

被折叠的 条评论
为什么被折叠?



