线程——消费者生产者
来源:互联网 发布:巫师2优化补丁 编辑:程序博客网 时间:2024/06/01 09:09
#include <stdio.h>
#include <pthread.h>
#include <time.h>
#include <string.h>
int resources;
pthread_mutex_t mutex;
void delay()
{
unsigned int x,y;
x = rand()%10000+1;
while (x > 0)
{
y = rand()%10000+1;
while (y > 0)
{
y--;
}
x--;
}
}
void *producer(void *arg)
{
while (1)
{
pthread_mutex_lock(&mutex);
delay();
resources += 2;
printf("Produce 2 resources\n");
pthread_mutex_unlock(&mutex);
}
}
void *consumer(void *arg)
{
while (1)
{
pthread_mutex_lock(&mutex);
if (resources <= 0)
{
pthread_mutex_unlock(&mutex);
continue;
}
delay();
resources--;
printf("Consumer 1 resources, %d left\n", resources);
pthread_mutex_unlock(&mutex);
}
}
int main()
{
pthread_t p1, c1, c2, c3;
int err;
srand((unsigned int)time(NULL));
pthread_mutex_init(&mutex, NULL);
err = pthread_create(&p1, NULL, producer, NULL);
if (-1 == err)
{
printf("create p1 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_create(&c1, NULL, consumer, NULL);
if (-1 == err)
{
printf("create c1 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_create(&c2, NULL, consumer, NULL);
if (-1 == err)
{
printf("create c2 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_create(&c3, NULL, consumer, NULL);
if (-1 == err)
{
printf("create c3 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_join(p1, NULL);
if (0 != err)
{
printf("wait p1 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_join(c1, NULL);
if (0 != err)
{
printf("wait c1 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_join(c2, NULL);
if (0 != err)
{
printf("wait c2 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_join(c3, NULL);
if (0 != err)
{
printf("wait c3 thread fail: %s\n", strerror(err));
return -1;
}
pthread_mutex_destroy(&mutex);
return 0;
}
#include <pthread.h>
#include <time.h>
#include <string.h>
int resources;
pthread_mutex_t mutex;
void delay()
{
unsigned int x,y;
x = rand()%10000+1;
while (x > 0)
{
y = rand()%10000+1;
while (y > 0)
{
y--;
}
x--;
}
}
void *producer(void *arg)
{
while (1)
{
pthread_mutex_lock(&mutex);
delay();
resources += 2;
printf("Produce 2 resources\n");
pthread_mutex_unlock(&mutex);
}
}
void *consumer(void *arg)
{
while (1)
{
pthread_mutex_lock(&mutex);
if (resources <= 0)
{
pthread_mutex_unlock(&mutex);
continue;
}
delay();
resources--;
printf("Consumer 1 resources, %d left\n", resources);
pthread_mutex_unlock(&mutex);
}
}
int main()
{
pthread_t p1, c1, c2, c3;
int err;
srand((unsigned int)time(NULL));
pthread_mutex_init(&mutex, NULL);
err = pthread_create(&p1, NULL, producer, NULL);
if (-1 == err)
{
printf("create p1 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_create(&c1, NULL, consumer, NULL);
if (-1 == err)
{
printf("create c1 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_create(&c2, NULL, consumer, NULL);
if (-1 == err)
{
printf("create c2 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_create(&c3, NULL, consumer, NULL);
if (-1 == err)
{
printf("create c3 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_join(p1, NULL);
if (0 != err)
{
printf("wait p1 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_join(c1, NULL);
if (0 != err)
{
printf("wait c1 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_join(c2, NULL);
if (0 != err)
{
printf("wait c2 thread fail: %s\n", strerror(err));
return -1;
}
err = pthread_join(c3, NULL);
if (0 != err)
{
printf("wait c3 thread fail: %s\n", strerror(err));
return -1;
}
pthread_mutex_destroy(&mutex);
return 0;
}
阅读全文
0 0
- 线程——消费者生产者
- 线程通信举例——生产者、消费者
- 线程同步——生产者消费者
- Java线程——生产者消费者
- Android线程—生产者和消费者
- 生产者—消费者模式
- 生产者—消费者模型
- 生产者—消费者模型
- 生产者—消费者模型
- 多线程—03—线程间通信、生产者消费者
- java线程同步经典——生产者消费者
- 线程同步经典问题——生产者消费者问题
- Linux——线程锁实现的生产者、消费者模型
- 线程操作案例——生产者和消费者
- JAVA线程同步——消费者和生产者模式
- java线程(2)——模拟生产者与消费者
- java多线程线程通信——生产者和消费者
- 利用线程解决生产者——消费者问题
- 问题 S: 说反话
- vb.net 教程 12-4 msHtml 5 偷梁换柱
- [3]React 深入浅出-----JSX简介
- Java密码学
- hdu 4442 Physical Examination
- 线程——消费者生产者
- UDP服务器、客户端的简单实现
- 合并txt文件
- 问题 T: A+B和C比大小
- const关键字
- perl 生成json树
- Angular 基础部分 1.1 简介
- Android View — Gradient 渐变
- 装饰者模式(Decorator Pattern)