Ozan Tezcan 8df6817ff0
Fix warnings (#115)
Fix visual studio warnings
2023-04-22 00:41:11 +03:00
..
2022-12-07 00:55:43 +03:00
2021-02-11 03:25:37 +03:00
2022-12-30 23:04:00 +03:00
2023-04-21 00:43:26 +03:00
2022-08-20 18:56:21 +03:00
2023-04-22 00:41:11 +03:00

Timer

Overview

  • Hashed timing wheel implementation.
  • Provides fast cancel(O(1)) and poll operations compared to a priority queue.
  • Timers in the same hash slot are not ordered between each other. So, basically
    this data structure trades accuracy for performance. Schedule a timer for
    10000ms and another for 10001ms and you might see 10001ms timer expires
    just before 10000ms timer. Default tick is 16 ms, so, timers in the same 16ms
    interval may expire out of order.

Usage

#include "sc_timer.h"

#include <errno.h>
#include <stdio.h>
#include <time.h>

uint64_t time_ms();
void sleep_ms(uint64_t milliseconds);


void callback(void *arg, uint64_t timeout, void *data)
{
    struct sc_timer *timer = arg;
    char *timer_name = data;

    printf("timeout : %zu, data : %s \n", timeout, timer_name);
    // Schedule back
    sc_timer_add(timer, "timer1", 1000);
}

int main(int argc, char *argv[])
{
    uint64_t next_timeout;
    struct sc_timer timer;

    sc_timer_init(&timer, time_ms());
    sc_timer_add(&timer, "timer1", 1000);

    while (true) {
        next_timeout = sc_timer_timeout(&timer, time_ms(), &timer, callback);
        sleep_ms(next_timeout);
    }

    return 0;
}