1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
|
/** 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;
}
|