yggdrasil/test.c

44 lines
1021 B
C
Raw Normal View History

#include <pthread.h>
2024-11-20 15:39:10 +02:00
#include <unistd.h>
#include <assert.h>
#include <stdio.h>
static pthread_mutex_t mutex;
2024-11-26 22:59:23 +02:00
static void *thread(void *arg) {
printf("[child] lock0\n");
2024-11-26 22:59:23 +02:00
pthread_mutex_lock(&mutex);
printf("[child] lock1\n");
pthread_mutex_lock(&mutex);
printf("[child] in inner lock!!!\n");
sleep(3);
pthread_mutex_unlock(&mutex);
printf("[child] in outer lock!!!\n");
2024-11-26 22:59:23 +02:00
pthread_mutex_unlock(&mutex);
printf("[child] unlocked!!!\n");
2024-11-26 22:59:23 +02:00
return NULL;
}
2024-11-20 15:39:10 +02:00
2024-11-15 23:18:04 +02:00
int main(int argc, const char **argv) {
pthread_mutexattr_t mutex_attr;
pthread_t handle0;
pthread_mutexattr_init(&mutex_attr);
pthread_mutexattr_settype(&mutex_attr, PTHREAD_MUTEX_RECURSIVE);
pthread_mutex_init(&mutex, &mutex_attr);
2024-11-26 22:59:23 +02:00
pthread_create(&handle0, NULL, thread, "thread0");
sleep(1);
2024-11-20 15:39:10 +02:00
2024-11-26 22:59:23 +02:00
pthread_mutex_lock(&mutex);
printf("[main] inside lock\n");
sleep(1);
2024-11-26 22:59:23 +02:00
pthread_mutex_unlock(&mutex);
2024-11-20 15:39:10 +02:00
2024-11-26 22:59:23 +02:00
pthread_join(handle0, NULL);
printf("[main] finished\n");
2024-11-20 15:39:10 +02:00
2024-11-11 15:19:36 +02:00
return 0;
}