• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Function Flow Runtime并发队列(C)
2
3## 概述
4
5FFRT并发队列提供了设置任务优先级(Priority)和队列并发度的能力,使得队列中的任务能同时在多个线程上执行,获得更高的并行效果。
6
7- **队列并发度**:通过队列最大并发度设置,可以控制同一时刻同时执行的任务数量。这有助于避免任务并发过多对系统资源造成冲击,从而保证系统的稳定性和性能。
8- **任务优先级**:用户可以为每个任务设置优先级,不同的任务将严格按照优先级进行调度和执行。相同优先级的任务按照排队顺序执行,高优先级的任务将优先于低优先级的任务执行,确保关键任务能够及时处理。
9
10## 示例:银行服务系统
11
12举例实现一个银行服务系统,每个客户向系统提交一个服务请求,可以区分普通用户和VIP用户,VIP用户的服务请求可以优先得到执行。
13银行系统中有2个窗口,可以并行取出用户提交的服务请求办理。可以利用FFRT的并行队列范式做如下建模:
14
15- **排队逻辑**:并行队列。
16- **服务窗口**:并行队列的并发度,同时也对应FFRT Worker数量。
17- **用户等级**:并行队列任务优先级。
18
19实现代码如下所示:
20
21```c
22#include <stdio.h>
23#include <unistd.h>
24#include "ffrt/ffrt.h"
25
26ffrt_queue_t create_bank_system(const char *name, int concurrency)
27{
28    ffrt_queue_attr_t queue_attr;
29    (void)ffrt_queue_attr_init(&queue_attr);
30    ffrt_queue_attr_set_max_concurrency(&queue_attr, concurrency);
31
32    // 创建一个并发队列
33    ffrt_queue_t queue = ffrt_queue_create(ffrt_queue_concurrent, name, &queue_attr);
34
35    // 队列创建完后需要销毁队列属性
36    ffrt_queue_attr_destroy(&queue_attr);
37    if (!queue) {
38        printf("create queue failed\n");
39        return NULL;
40    }
41
42    printf("create bank system successfully\n");
43    return queue;
44}
45
46void destroy_bank_system(ffrt_queue_t queue_handle)
47{
48    ffrt_queue_destroy(queue_handle);
49    printf("destroy bank system successfully\n");
50}
51
52void bank_business(void *arg)
53{
54    usleep(100 * 1000);
55    const char *data = (const char *)arg;
56    printf("saving or withdraw for %s\n", data);
57}
58
59// 封装提交队列任务函数
60ffrt_task_handle_t commit_request(ffrt_queue_t bank, void (*func)(void *), const char *name,
61    ffrt_queue_priority_t level, int delay)
62{
63    ffrt_task_attr_t task_attr;
64    (void)ffrt_task_attr_init(&task_attr);
65    ffrt_task_attr_set_name(&task_attr, name);
66    ffrt_task_attr_set_queue_priority(&task_attr, level);
67    ffrt_task_attr_set_delay(&task_attr, delay);
68
69    return ffrt_queue_submit_h_f(bank, func, name, &task_attr);
70}
71
72// 封装取消队列任务函数
73int cancel_request(ffrt_task_handle_t request)
74{
75    return ffrt_queue_cancel(request);
76}
77
78// 封装等待队列任务函数
79void wait_for_request(ffrt_task_handle_t task)
80{
81    ffrt_queue_wait(task);
82}
83
84int main()
85{
86    ffrt_queue_t bank = create_bank_system("Bank", 2);
87    if (!bank) {
88        printf("create bank system failed\n");
89        return -1;
90    }
91
92    ffrt_task_handle_t task1 = commit_request(bank, bank_business, "customer1", ffrt_queue_priority_low, 0);
93    ffrt_task_handle_t task2 = commit_request(bank, bank_business, "customer2", ffrt_queue_priority_low, 0);
94    // VIP享受更优先的服务
95    ffrt_task_handle_t task3 = commit_request(bank, bank_business, "customer3 VIP", ffrt_queue_priority_high, 0);
96    ffrt_task_handle_t task4 = commit_request(bank, bank_business, "customer4", ffrt_queue_priority_low, 0);
97    ffrt_task_handle_t task5 = commit_request(bank, bank_business, "customer5", ffrt_queue_priority_low, 0);
98
99    // 取消客户4的服务
100    cancel_request(task4);
101
102    // 等待所有的客户服务完成
103    wait_for_request(task5);
104    destroy_bank_system(bank);
105
106    ffrt_task_handle_destroy(task1);
107    ffrt_task_handle_destroy(task2);
108    ffrt_task_handle_destroy(task3);
109    ffrt_task_handle_destroy(task4);
110    ffrt_task_handle_destroy(task5);
111    return 0;
112}
113```
114
115## 接口说明
116
117上述样例中涉及到主要的FFRT的接口包括:
118
119| 名称                                                                                               | 描述                   |
120| -------------------------------------------------------------------------------------------------- | ---------------------- |
121| [ffrt_queue_create](ffrt-api-guideline-c.md#ffrt_queue_create)                                     | 创建队列。             |
122| [ffrt_queue_destroy](ffrt-api-guideline-c.md#ffrt_queue_destroy)                                   | 销毁队列。             |
123| [ffrt_task_attr_set_queue_priority](ffrt-api-guideline-c.md#ffrt_task_attr_set_queue_priority)     | 设置队列任务优先级。   |
124| [ffrt_queue_attr_set_max_concurrency](ffrt-api-guideline-c.md#ffrt_queue_attr_set_max_concurrency) | 设置并发队列的并发度。 |
125| [ffrt_queue_submit_h_f](ffrt-api-guideline-c.md#ffrt_queue_submit_h_f)                             | 向队列提交一个任务。   |
126
127> **说明:**
128>
129> - 如何使用FFRT C++ API详见:[FFRT C++接口三方库使用指导](ffrt-development-guideline.md#using-ffrt-c-api-1)。
130> - 使用FFRT C接口或C++接口时,都可以通过FFRT C++接口三方库简化头文件包含,即使用`#include "ffrt/ffrt.h"`头文件包含语句。
131
132## 约束限制
133
1341. `ffrt_queue_attr_t`必须先调用`ffrt_queue_attr_init`初始化后再设置/获取属性,不再使用后需要显式调用`ffrt_queue_attr_destroy`释放资源。
1352. `ffrt_queue_t`必须在进程退出前显式调用`ffrt_queue_destroy`释放资源。
1363. 并发队列最大并发度建议控制在合理范围内,配置过大超过Worker线程数没有意义,配置过小可能导致系统资源利用率不足。
137