Linux多线程通信
来源:互联网 发布:手机网游破解软件 编辑:程序博客网 时间:2024/06/06 10:52
多线程编程作为程序员必须掌握的一项技能,看到一篇好的博客,适合初学者入门。以一个简单的、著名的生产者/消费者问题实例,比较清晰地阐述了linux线程的控制和通信。一组生产者线程与一组消费者线程通过缓冲区发生联系。生产者线程将生产的产品送入缓冲区,消费者线程则从中取出产品。缓冲区有N个,是一个环形的缓冲池。原文链接如下(链接),代码如下,看懂这部分代码就算入门Linux多线程了。
#include <stdio.h>#include <pthread.h>#define BUFFER_SIZE 16//缓冲区数量struct prodcons{//缓冲区相关数据结构int buffer[BUFFER_SIZE];//实际数据存放的数组pthread_mutex_t lock;//互斥体lock用于对缓冲区的互斥操作int readpos,writepos;//读写指针pthread_cond_t notempty;//缓冲区非空的条件变量pthread_cond_t notfull;//缓冲区未满的条件变量};//初始化缓冲区结构void init(struct prodcons *b){pthread_mutex_init(&b->lock,NULL);pthread_cond_init(&b->notempty,NULL);pthread_cond_init(&b->notfull,NULL);b->readpos = 0;b->writepos = 0;}//生产者将产品放入缓冲区,这里是存入一个整数void put(struct prodcons *b,int data){pthread_mutex_lock(&b->lock);//等待缓冲区未满if((b->writepos+1)%BUFFER_SIZE == b->readpos){pthread_cond_wait(&b->notfull,&b->lock);//用来等待条件变量被设置}//写数据,并移动指针b->buffer[b->writepos]=data;b->writepos++;if(b->writepos >= BUFFER_SIZE){b->writepos = 0;}//设置缓冲区非空的条件变量pthread_cond_signal(&b->notempty);//解除某一个等待线程的阻塞状态pthread_mutex_unlock(&b->lock);//给互斥变量解锁}//消费者从缓冲区取出整数int get(struct prodcons *b){int data;pthread_mutex_lock(&b->lock);//等待缓冲区非空if(b->writepos == b->readpos){pthread_cond_wait(&b->notempty,&b->lock);}//读数据,移动读指针data = b->buffer[b->readpos];b->readpos++;if(b->readpos >= BUFFER_SIZE){b->readpos = 0;}//设置缓冲区未满的条件变量pthread_cond_signal(&b->notfull);pthread_mutex_unlock(&b->lock);return data;}/*测试:生产者线程将1到10000的整数送入缓冲区,消费者线程从缓冲区中获取整数,两者都打印信息*/#define OVER (-1)struct prodcons buffer;void *producer(void *data){int n;for(n=0;n<20;n++){printf("%d---->\n",n);put(&buffer,n);}put(&buffer,OVER);return NULL;}void *consumer(void *data){int d;while(1){d = get(&buffer);if(d == OVER){break;}printf("--->%d\n",d);}return NULL;}int main(void){pthread_t th_a,th_b;void *retval;init(&buffer);//创建生产者和消费者线程pthread_create(&th_a,NULL,producer,0);pthread_create(&th_b,NULL,consumer,0);//等待两个线程结束pthread_join(th_a,&retval);pthread_join(th_b,&retval);return 0;}
阅读全文
1 0
- Linux 多线程通信
- Linux 多线程通信
- Linux 多线程通信
- Linux 多线程通信
- Linux多线程通信
- Linux多线程通信
- Linux多线程通信
- Linux多线程通信及同步
- Linux多线程通信及同步
- 进程间通信与线程间通信 . windows下多线程通信方法 Linux 多线程通信
- 转 Linux多线程通信及同步
- 关于Linux下多线程之间通信
- Linux 多线程通信方面的问题
- 多线程通信
- 多线程通信
- 多线程通信
- 多线程通信
- 多线程通信
- 栈,队列和二叉树的实现
- Sqoop Flume 数据采集引擎
- hbase 启动报错
- 自动化测试第二课:打开浏览器
- java多线程设计模式之Producer-Consumer模式(一)
- Linux多线程通信
- unity-lua开发环境
- Lengthening Sticks(容斥,组合数学)
- PDO执行execute方法后无任何返回,通过try catch 得到如下异常信息
- maven 的安装和配置
- JVM介绍
- 【springMVC】使用maven时,已经添加了spring-web和spring-webmvc依赖,却没有注解,还有其他报错
- 沉下心来
- 洛谷mNOIP day2t1 60分