main.c 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <unistd.h>
  4. #include <uv.h>
  5. #define FIB_UNTIL 25
  6. uv_loop_t *loop;
  7. uv_work_t fib_reqs[FIB_UNTIL];
  8. long fib_(long t) {
  9. if (t == 0 || t == 1)
  10. return 1;
  11. else
  12. return fib_(t-1) + fib_(t-2);
  13. }
  14. void fib(uv_work_t *req) {
  15. int n = *(int *) req->data;
  16. if (random() % 2)
  17. sleep(1);
  18. else
  19. sleep(3);
  20. long fib = fib_(n);
  21. fprintf(stderr, "%dth fibonacci is %lu\n", n, fib);
  22. }
  23. void after_fib(uv_work_t *req, int status) {
  24. if (status == UV_ECANCELED)
  25. fprintf(stderr, "Calculation of %d cancelled.\n", *(int *) req->data);
  26. }
  27. void signal_handler(uv_signal_t *req, int signum)
  28. {
  29. printf("Signal received!\n");
  30. int i;
  31. for (i = 0; i < FIB_UNTIL; i++) {
  32. uv_cancel((uv_req_t*) &fib_reqs[i]);
  33. }
  34. uv_signal_stop(req);
  35. }
  36. int main() {
  37. loop = uv_default_loop();
  38. int data[FIB_UNTIL];
  39. int i;
  40. for (i = 0; i < FIB_UNTIL; i++) {
  41. data[i] = i;
  42. fib_reqs[i].data = (void *) &data[i];
  43. uv_queue_work(loop, &fib_reqs[i], fib, after_fib);
  44. }
  45. uv_signal_t sig;
  46. uv_signal_init(loop, &sig);
  47. uv_signal_start(&sig, signal_handler, SIGINT);
  48. return uv_run(loop, UV_RUN_DEFAULT);
  49. }