timer.c 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #include "hloop.h"
  2. #include "hbase.h"
  3. void on_timer(htimer_t* timer) {
  4. printf("time=%lus on_timer\n", hloop_now(hevent_loop(timer)));
  5. }
  6. void on_timer_add(htimer_t* timer) {
  7. printf("time=%lus on_timer_add\n", hloop_now(hevent_loop(timer)));
  8. htimer_add(hevent_loop(timer), on_timer_add, 1000, 1);
  9. }
  10. void on_timer_del(htimer_t* timer) {
  11. printf("time=%lus on_timer_del\n", hloop_now(hevent_loop(timer)));
  12. htimer_del(timer);
  13. }
  14. void on_timer_reset(htimer_t* timer) {
  15. printf("time=%lus on_timer_reset\n", hloop_now(hevent_loop(timer)));
  16. htimer_reset((htimer_t*)hevent_userdata(timer));
  17. }
  18. void on_timer_quit(htimer_t* timer) {
  19. printf("time=%lus on_timer_quit\n", hloop_now(hevent_loop(timer)));
  20. hloop_stop(hevent_loop(timer));
  21. }
  22. void cron_hourly(htimer_t* timer) {
  23. time_t tt;
  24. time(&tt);
  25. printf("time=%lus cron_hourly: %s\n", hloop_now(hevent_loop(timer)), ctime(&tt));
  26. }
  27. int main() {
  28. MEMCHECK;
  29. hloop_t* loop = hloop_new(0);
  30. // on_timer_add triggered forever
  31. htimer_add(loop, on_timer_add, 1000, 1);
  32. // on_timer_del triggered just once
  33. htimer_add(loop, on_timer_del, 1000, 10);
  34. // on_timer triggered after 10s
  35. htimer_t* reseted = htimer_add(loop, on_timer, 5000, 1);
  36. htimer_t* reset = htimer_add(loop, on_timer_reset, 1000, 5);
  37. hevent_set_userdata(reset, reseted);
  38. // cron_hourly next triggered in one minute
  39. int minute = time(NULL)%3600/60;
  40. htimer_add_period(loop, cron_hourly, minute+1, -1, -1, -1, -1, INFINITE);
  41. // quit application after 1 min
  42. htimer_add(loop, on_timer_quit, 60000, 1);
  43. printf("time=%lus begin\n", hloop_now(loop));
  44. hloop_run(loop);
  45. printf("time=%lus stop\n", hloop_now(loop));
  46. hloop_free(&loop);
  47. return 0;
  48. }