| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- #include <stddef.h>
- #include <stdio.h>
- #include <misc/debug.h>
- #include <base/BLog.h>
- #include <base/DebugObject.h>
- #include <threadwork/BThreadWork.h>
- BReactor reactor;
- BThreadWorkDispatcher twd;
- BThreadWork tw1;
- BThreadWork tw2;
- BThreadWork tw3;
- int num_left;
- static void handler_done (void *user)
- {
- printf("work done\n");
-
- num_left--;
-
- if (num_left == 0) {
- printf("all works done, quitting\n");
- BReactor_Quit(&reactor, 0);
- }
- }
- static void work_func (void *user)
- {
- unsigned int x = 0;
-
- for (int i = 0; i < 10000; i++) {
- for (int j = 0; j < 10000; j++) {
- x++;
- }
- }
- }
- static void dummy_works (int n)
- {
- for (int i = 0; i < n; i++) {
- BThreadWork tw_tmp;
- BThreadWork_Init(&tw_tmp, &twd, handler_done, NULL, work_func, NULL);
- BThreadWork_Free(&tw_tmp);
- }
- }
- int main ()
- {
- BLog_InitStdout();
- BLog_SetChannelLoglevel(BLOG_CHANNEL_BThreadWork, BLOG_DEBUG);
-
- if (!BReactor_Init(&reactor)) {
- DEBUG("BReactor_Init failed");
- goto fail1;
- }
-
- if (!BThreadWorkDispatcher_Init(&twd, &reactor, 1)) {
- DEBUG("BThreadWorkDispatcher_Init failed");
- goto fail2;
- }
-
- dummy_works(200);
-
- BThreadWork_Init(&tw1, &twd, handler_done, NULL, work_func, NULL);
-
- BThreadWork_Init(&tw2, &twd, handler_done, NULL, work_func, NULL);
-
- BThreadWork_Init(&tw3, &twd, handler_done, NULL, work_func, NULL);
-
- dummy_works(200);
-
- num_left = 3;
-
- BReactor_Exec(&reactor);
-
- BThreadWork_Free(&tw3);
- BThreadWork_Free(&tw2);
- BThreadWork_Free(&tw1);
- BThreadWorkDispatcher_Free(&twd);
- fail2:
- BReactor_Free(&reactor);
- fail1:
- BLog_Free();
- DebugObjectGlobal_Finish();
- return 0;
- }
|