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

原创 2013年12月03日 11:59:12

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

linux下多线程编程,各种锁,信号量

转自http://mingxinglai.com/cn/2013/06/mutil-threads/ 最近研究mysql源码,各种锁,各种互斥,好在我去年认真学了《unix环境高级编程》, 虽然...
  • JY_Sharer
  • JY_Sharer
  • 2013年11月25日 19:47
  • 1864

使用信号量进行同步的共享内存机制

一、简介 共享内存为在多个进程之间共享和传递数据提供了一种有效的方式。 但它本身并未提供同步机制。 在实际编程中,可以使用   信号量,   传递消息(使用管道或IPC消...
  • qq_33336155
  • qq_33336155
  • 2016年07月11日 15:28
  • 1410

linux多线程编程入门-同步机制-互斥量

所谓同步,并不是日常用语中的同时进行的意思。这里的同步是指如何阻止同步进行的意思。 互斥量,又称互斥锁,它允许程序员锁住某个对象,使得每次只能有一个线程访问它。为了控制对关键代码的访问,必须在进入这段...
  • a304672343
  • a304672343
  • 2013年12月03日 10:40
  • 653

Linux多线程编程入门-同步机制-条件变量

Linux平台上触发条件变量则自动复位。 条件变量的置位和复位有两种常用模型:第一种模型是当条件变量置位(signaled)以后,如果当前没有线程在等待,其状态会保持为置位(signaled),直到...
  • a304672343
  • a304672343
  • 2013年12月04日 14:56
  • 651

Linux线程同步机制的几种方法总结与对比

线程同步机制的几种方法总结与对比 需要线程同步的原因: 当有多个线程同时访问一个共享内存里面的变量时,有时会出现一个线程正在修改该变量的值,而其他的线程正在读取数据,可能就会导致错误。   实...
  • u010853261
  • u010853261
  • 2014年10月28日 14:46
  • 1442

【C/C++多线程编程之七】pthread信号量

多线程编程之信号量      Pthread是 POSIX threads 的简称,是POSIX的线程标准。          互斥量用来处理一个共享资源的同步访问问题,当有多个共享资源时,就...
  • Jiangweihll
  • Jiangweihll
  • 2014年05月03日 16:13
  • 7232

Linux 多线程编程(实现生产者消费者模型)

Linux 多线程编程线程分类线程按照其调度者可以分为用户级线程和内核级线程两种。内核级线程在一个系统上实现线程模型的方式有好几种,因内核和用户空间提供的支持而有一定程度的级别差异。最简单的模型是在内...
  • wj199395
  • wj199395
  • 2017年08月27日 16:41
  • 315

信号 信号量 同步机制 异步机制

信号与信号量的区别[转] Posted on 2012-12-19 10:27 vivi_wind 阅读(77) 评论(0) 编辑 收藏  信号量(Semaphore),有时被称为信号灯,是在多环...
  • a174787252
  • a174787252
  • 2013年06月05日 15:22
  • 1188

从零学习linux多线程编程--第一篇

线程(thread)技术早在60年代就被提出,但真正应用多线程到 ***作系统中去,是在80年代中期,solaris是这方面的佼佼者。传统的Unix也支持线程的概念,但是在一个进程(process)中...
  • sunsnow2
  • sunsnow2
  • 2014年08月19日 20:59
  • 554

再聊多线程04--信号量

今天整理“信号量”的相关知识,其实想想也蛮有趣的,锁,互斥,信号量都可以实现线程同步,在framework里面主要有三种。 :ManualResetEvent :AutoResetEvent : Se...
  • xiangxizhishi
  • xiangxizhishi
  • 2018年01月30日 11:39
  • 28
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Linux多线程编程入门-同步机制-信号量
举报原因:
原因补充:

(最多只允许输入30个字)