CLOCK_MONOTONIC and pthread_mutex_timedlock / pthread_cond_timedwait

前端 未结 2 1725
忘了有多久
忘了有多久 2021-02-01 20:04

The pthread_mutex_timedlock documentation says that abs_timeout takes a CLOCK_REALTIME. However, we all know that it is inappropriate for timing a spec

相关标签:
2条回答
  • 2021-02-01 20:26

    Having looked at the documentation and pthread.h, I can't find a way to make pthread_mutex_timedlock use CLOCK_MONOTONIC so I assume that's not (currently) possible. For pthread_cond_timedwait, however, you can use code like this:

    pthread_condattr_t attr;
    pthread_cond_t cond;
    /* ... */
    pthread_condattr_init(&attr);
    pthread_condattr_setclock(&attr, CLOCK_MONOTONIC);
    pthread_cond_init(&cond, &attr);
    

    I've omitted error code checking for clarity, but of course you should do that.

    I assume that CLOCK_REALTIME is used because it's always available whereas in principle CLOCK_MONOTONIC is optional. Also, I wonder if setting absolute timeouts makes it easier to recover after system calls get interrupted by signals and the like.

    However, it does seem quite inconsistent that the clock can be set in some cases and not others - there really should be a pthread_mutexattr_setclock(), but alas there does not seem to be one. I guess you'll just have to hope someone doesn't set the clock!

    0 讨论(0)
  • 2021-02-01 20:31

    On OS X and FreeBSD, you can use kqueue and kevent. See my answer here: https://stackoverflow.com/a/31174803/432

    0 讨论(0)
提交回复
热议问题