关闭

Linux多线程编程入门-同步机制-信号量

460人阅读 评论(0) 收藏 举报
分类:

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增加信号量的值为止。

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:49905次
    • 积分:743
    • 等级:
    • 排名:千里之外
    • 原创:27篇
    • 转载:1篇
    • 译文:0篇
    • 评论:4条
    文章分类
    最新评论