/** Hold several types of synchronization objects locked as long as specified.
*/
#define _GNU_SOURCE 1
#include <assert.h>
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <unistd.h>
static void delay_ms(const int ms)
{
struct timespec ts;
assert(ms >= 0);
ts.tv_sec = ms / 1000;
ts.tv_nsec = (ms % 1000) * 1000 * 1000;
nanosleep(&ts, 0);
}
int main(int argc, char** argv)
{
int interval = 0;
int optchar;
pthread_mutex_t mutex;
pthread_mutexattr_t mutexattr;
pthread_rwlock_t rwlock;
while ((optchar = getopt(argc, argv, "i:")) != EOF)
{
switch (optchar)
{
case 'i':
interval = atoi(optarg);
break;
default:
fprintf(stderr, "Usage: %s [-i <interval time in ms>].\n", argv[0]);
break;
}
}
fprintf(stderr, "Locking mutex ...\n");
pthread_mutexattr_init(&mutexattr);
pthread_mutexattr_settype(&mutexattr, PTHREAD_MUTEX_RECURSIVE);
pthread_mutex_init(&mutex, &mutexattr);
pthread_mutexattr_destroy(&mutexattr);
pthread_mutex_lock(&mutex);
delay_ms(interval);
pthread_mutex_lock(&mutex);
pthread_mutex_unlock(&mutex);
pthread_mutex_unlock(&mutex);
pthread_mutex_destroy(&mutex);
fprintf(stderr, "Locking rwlock exclusively ...\n");
pthread_rwlock_init(&rwlock, 0);
pthread_rwlock_wrlock(&rwlock);
delay_ms(interval);
pthread_rwlock_unlock(&rwlock);
pthread_rwlock_destroy(&rwlock);
fprintf(stderr, "Locking rwlock shared ...\n");
pthread_rwlock_init(&rwlock, 0);
pthread_rwlock_rdlock(&rwlock);
delay_ms(interval);
pthread_rwlock_rdlock(&rwlock);
pthread_rwlock_unlock(&rwlock);
pthread_rwlock_unlock(&rwlock);
pthread_rwlock_destroy(&rwlock);
fprintf(stderr, "Done.\n");
return 0;
}