sem_wait和sem_post
时间: 2023-07-12 10:08:47 浏览: 123
`sem_wait`和`sem_post`是Linux系统提供的两个信号量操作函数,常见于多线程编程中的同步和互斥机制。
`sem_wait`函数用于等待信号量,如果信号量的值大于0,则将其减1,线程继续执行;如果信号量的值为0,则线程被阻塞,直到该信号量变为非零为止。
`sem_post`函数用于释放信号量,将信号量的值加1,同时唤醒可能因此而被阻塞的线程。
下面是一个使用信号量的示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <semaphore.h>
#define MAX_THREADS 10
sem_t sem;
void *thread_function(void *arg) {
int tid = *(int *)arg;
printf("Thread %d waiting for semaphore...\n", tid);
sem_wait(&sem);
printf("Thread %d acquired semaphore!\n", tid);
// do some critical work here
printf("Thread %d releasing semaphore...\n", tid);
sem_post(&sem);
printf("Thread %d released semaphore!\n", tid);
pthread_exit(NULL);
}
int main() {
pthread_t threads[MAX_THREADS];
int thread_ids[MAX_THREADS];
int i;
sem_init(&sem, 0, 1); // initialize semaphore with value 1
for (i = 0; i < MAX_THREADS; i++) {
thread_ids[i] = i;
pthread_create(&threads[i], NULL, thread_function, &thread_ids[i]);
}
for (i = 0; i < MAX_THREADS; i++) {
pthread_join(threads[i], NULL);
}
sem_destroy(&sem); // destroy semaphore
return 0;
}
```
在上面的代码中,我们创建了一个包含10个线程的线程池,每个线程都需要获取信号量进行一些关键性工作。由于我们在初始化信号量时将其值设置为1,因此只有一个线程可以同时获取信号量。其他线程将被阻塞,直到该信号量被释放。
在每个线程完成关键性工作后,它会释放信号量,以允许其他线程获取它并进行关键性工作。
这个示例展示了如何使用信号量实现同步和互斥。
阅读全文