int sem_init(sem_t *sem, int pshared, unsigned int value);
pshared:控制信号量的类型,0表示这个信号量是当前进程的局部信号量,否则,这个信号量就可以在多个进程之间共享。 value:信号量的初始值。
int sem_post(sem_t *sem);以原子操作的方式给信号量的值加1。这里的原子操作指两个线程企图同时给一个 信号量加1,它们之间不会互相干扰。会正确的加为2.
int sem_wait(sem_t *sem);以原子操作的方式给信号量的值减1。它会等待直到信号量有一个非零值才会开始减法操作。
int sem_destory(sem_t *sem); 清理信号量所拥有的所有资源。
代码如下:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
#include <semaphore.h>
void * thread_function(void * arg);
sem_t bin_sem;
#define WORK_SIZE 1024
char work_area[WORK_SIZE];
int main()
{
int res;
pthread_t a_thread;
void * thread_result;
res = sem_init(&bin_sem, 0, 0);
res = pthread_create(&a_thread, NULL, thread_function, NULL);
printf("Input some some text. Enter 'end' to finish.\n");
while(strncmp("end", work_area, 3) != 0) {
fgets(work_area, WORK_SIZE, stdin);
sem_post(&bin_sem);
}
printf("\nWaiting for thread to finish...\n");
res = pthread_join(a_thread, &thread_result);
printf("Thread joined\n");
sem_destroy(&bin_sem);
exit(EXIT_SUCCESS);
}
void * thread_function(void * arg) {
sem_wait(&bin_sem);
while(strncmp("end", work_area, 3) != 0) {
printf("You input %d characters\n", strlen(work_area)-1);
sem_wait(&bin_sem);
}
pthread_exit(NULL);
}
解析:
初始化信号量时,把它的值设置为0。这样,在 线程函数启动时,sem_wait函数调用就会阻塞并等待信号量变为非零值。
主线程中,等待直到有文本输入,然后调用sem_post增加信号量的值,这将立即令另一个线程从sem_wait的等待中返回并开始执行。在统计完字符个数之后,它再次调用sem_wait并再次被阻塞,直到主线程再次调用sem_post增加信号量的值为止。