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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值