加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

Linux环境下实现生产者消费者问题

发布时间:2020-12-13 14:01:03 所属栏目:Linux 来源:网络整理
导读:div class="cnblogs_code" include stdio.hspan style="color: #000000;" include semaphore.hspan style="color: #000000;" include stdlib.hspan style="color: #000000;" include pthread.hspan style="color: #000000;" include unistd.h span style="co

<div class="cnblogs_code">

include <stdio.h><span style="color: #000000;">

include <semaphore.h><span style="color: #000000;">

include <stdlib.h><span style="color: #000000;">

include <pthread.h><span style="color: #000000;">

include <unistd.h>

<span style="color: #0000ff;">#define N1 3<span style="color: #008000;">//<span style="color: #008000;">定义3个生产者
<span style="color: #0000ff;">#define N2 4<span style="color: #008000;">//<span style="color: #008000;">定义4 个消费者
<span style="color: #0000ff;">#define M 10<span style="color: #008000;">//<span style="color: #008000;">定义10个大小缓冲区

<span style="color: #0000ff;">int <span style="color: #0000ff;">in = <span style="color: #800080;">0<span style="color: #000000;">;
<span style="color: #0000ff;">int <span style="color: #0000ff;">out = <span style="color: #800080;">0<span style="color: #000000;">;

<span style="color: #0000ff;">int buff[M] = {<span style="color: #800080;">0};<span style="color: #008000;">//<span style="color: #008000;">缓冲区大小为10
<span style="color: #000000;">
sem_t empty_sem;<span style="color: #008000;">//<span style="color: #008000;">空缓冲区数量
sem_t full_sem;<span style="color: #008000;">//<span style="color: #008000;">满缓冲区数量
pthread_mutex_t mutex;<span style="color: #008000;">//<span style="color: #008000;">互斥访问缓冲区

<span style="color: #0000ff;">int product_id = <span style="color: #800080;">0<span style="color: #000000;">;
<span style="color: #0000ff;">int consumer_id = <span style="color: #800080;">0<span style="color: #000000;">;

<span style="color: #0000ff;">int<span style="color: #000000;"> data;
FILE *<span style="color: #000000;">fp;

<span style="color: #0000ff;">void *<span style="color: #000000;"> product()
{
<span style="color: #0000ff;">int id = ++<span style="color: #000000;">product_id;
<span style="color: #0000ff;">while(<span style="color: #800080;">1<span style="color: #000000;">)
{
sleep(<span style="color: #800080;">1<span style="color: #000000;">);
sem_wait(&<span style="color: #000000;">empty_sem);
pthread_mutex_lock(&<span style="color: #000000;">mutex);
<span style="color: #008000;">//<span style="color: #008000;">if(feof(fp) != 0) fseek(fp,SEEK_SET);
<span style="color: #0000ff;">if(fscanf(fp,<span style="color: #800000;">"<span style="color: #800000;">%d<span style="color: #800000;">",&data)==<span style="color: #000000;">EOF)
{
fseek(fp,<span style="color: #800080;">0<span style="color: #000000;">,SEEK_SET);
fscanf(fp,<span style="color: #800000;">"<span style="color: #800000;">%d<span style="color: #800000;">",&<span style="color: #000000;">data);
}
<span style="color: #0000ff;">in = <span style="color: #0000ff;">in %<span style="color: #000000;"> M;
buff[<span style="color: #0000ff;">in] =<span style="color: #000000;"> data;
printf(<span style="color: #800000;">"<span style="color: #800000;">Producter %d produce %d in position %dn<span style="color: #800000;">",id,buff[<span style="color: #0000ff;">in],<span style="color: #0000ff;">in<span style="color: #000000;">);
++<span style="color: #0000ff;">in<span style="color: #000000;">;
pthread_mutex_unlock(&<span style="color: #000000;">mutex);
sem_post(&<span style="color: #000000;">full_sem);
}
}

<span style="color: #0000ff;">void *<span style="color: #000000;">consume()
{
<span style="color: #0000ff;">int id = ++<span style="color: #000000;">consumer_id;

</span><span style="color: #0000ff;"&gt;while</span>(<span style="color: #800080;"&gt;1</span><span style="color: #000000;"&gt;)
{
    sleep(</span><span style="color: #800080;"&gt;1</span><span style="color: #000000;"&gt;);
    sem_wait(</span>&amp;<span style="color: #000000;"&gt;full_sem);
    pthread_mutex_lock(</span>&amp;<span style="color: #000000;"&gt;mutex);

    </span><span style="color: #0000ff;"&gt;out</span> = <span style="color: #0000ff;"&gt;out</span> %<span style="color: #000000;"&gt; M;
    printf(</span><span style="color: #800000;"&gt;"</span><span style="color: #800000;"&gt;Consumer %d take product  %d in position %dn</span><span style="color: #800000;"&gt;"</span>,buff[<span style="color: #0000ff;"&gt;out</span>],<span style="color: #0000ff;"&gt;out</span><span style="color: #000000;"&gt;);
    buff[</span><span style="color: #0000ff;"&gt;out</span>] = <span style="color: #800080;"&gt;0</span><span style="color: #000000;"&gt;;
    </span>++<span style="color: #0000ff;"&gt;out</span><span style="color: #000000;"&gt;;

    pthread_mutex_unlock(</span>&amp;<span style="color: #000000;"&gt;mutex);
    sem_post(</span>&amp;<span style="color: #000000;"&gt;empty_sem);

}

}

<span style="color: #0000ff;">int<span style="color: #000000;"> main()
{
pthread_t id1[N1];<span style="color: #008000;">//<span style="color: #008000;">定义生产者线程
pthread_t id2[N2];<span style="color: #008000;">//<span style="color: #008000;">定义消费者线程

<span style="color: #0000ff;"&gt;int</span><span style="color: #000000;"&gt; i;
</span><span style="color: #0000ff;"&gt;int</span><span style="color: #000000;"&gt; ret1[N1];
</span><span style="color: #0000ff;"&gt;int</span><span style="color: #000000;"&gt; ret2[N2];

</span><span style="color: #0000ff;"&gt;int</span> ini1 = sem_init(&amp;empty_sem,<span style="color: #800080;"&gt;0</span>,M);  <span style="color: #008000;"&gt;//</span><span style="color: #008000;"&gt;初始化空缓冲区 为 M(10)</span>
<span style="color: #0000ff;"&gt;int</span> ini2 = sem_init(&amp;full_sem,<span style="color: #800080;"&gt;0</span>);<span style="color: #008000;"&gt;//</span><span style="color: #008000;"&gt;初始化满缓冲区  0</span>
<span style="color: #0000ff;"&gt;if</span>(ini1 &amp;&amp; ini2 != <span style="color: #800080;"&gt;0</span><span style="color: #000000;"&gt;)
{
    printf(</span><span style="color: #800000;"&gt;"</span><span style="color: #800000;"&gt;Sem init failedn</span><span style="color: #800000;"&gt;"</span><span style="color: #000000;"&gt;);
    exit(</span><span style="color: #800080;"&gt;1</span><span style="color: #000000;"&gt;);
}

</span><span style="color: #0000ff;"&gt;int</span> ini3 = pthread_mutex_init(&amp;mutex,NULL);<span style="color: #008000;"&gt;//</span><span style="color: #008000;"&gt;初始化互斥信号量</span>
<span style="color: #0000ff;"&gt;if</span>(ini3 != <span style="color: #800080;"&gt;0</span><span style="color: #000000;"&gt; )
{
    printf(</span><span style="color: #800000;"&gt;"</span><span style="color: #800000;"&gt;mutex init failedn</span><span style="color: #800000;"&gt;"</span><span style="color: #000000;"&gt;);
    exit(</span><span style="color: #800080;"&gt;1</span><span style="color: #000000;"&gt;);
}

fp </span>= fopen(<span style="color: #800000;"&gt;"</span><span style="color: #800000;"&gt;/.data.txt</span><span style="color: #800000;"&gt;"</span>,<span style="color: #800000;"&gt;"</span><span style="color: #800000;"&gt;r</span><span style="color: #800000;"&gt;"</span>);<span style="color: #008000;"&gt;//</span><span style="color: #008000;"&gt;打开文件Data.txt</span>
<span style="color: #0000ff;"&gt;if</span>(fp == NULL) exit(<span style="color: #800080;"&gt;1</span><span style="color: #000000;"&gt;);

</span><span style="color: #0000ff;"&gt;for</span>(i = <span style="color: #800080;"&gt;0</span>; i < N1; i++<span style="color: #000000;"&gt;)
{
    ret1[i] </span>= pthread_create(&amp;id1[i],NULL,product,(<span style="color: #0000ff;"&gt;void</span>*)(&amp;i));<span style="color: #008000;"&gt;//</span><span style="color: #008000;"&gt;创建生产者线程</span>
    <span style="color: #0000ff;"&gt;if</span>(ret1[i] != <span style="color: #800080;"&gt;0</span><span style="color: #000000;"&gt;)
    {
        printf(</span><span style="color: #800000;"&gt;"</span><span style="color: #800000;"&gt;product%d creat failedn</span><span style="color: #800000;"&gt;"</span><span style="color: #000000;"&gt;,i);
        exit(</span><span style="color: #800080;"&gt;1</span><span style="color: #000000;"&gt;);
    }
}

</span><span style="color: #0000ff;"&gt;for</span>(i = <span style="color: #800080;"&gt;0</span>; i< N2; i++<span style="color: #000000;"&gt;)
{
    ret2[i] </span>= pthread_create(&amp;id2[i],consume,NULL);<span style="color: #008000;"&gt;//</span><span style="color: #008000;"&gt;创建消费者线程</span>
    <span style="color: #0000ff;"&gt;if</span>(ret2[i] != <span style="color: #800080;"&gt;0</span><span style="color: #000000;"&gt;)
    {
        printf(</span><span style="color: #800000;"&gt;"</span><span style="color: #800000;"&gt;consumer%d creat failedn</span><span style="color: #800000;"&gt;"</span><span style="color: #000000;"&gt;,i);
        exit(</span><span style="color: #800080;"&gt;1</span><span style="color: #000000;"&gt;);
    }
}


</span><span style="color: #0000ff;"&gt;for</span>(i = <span style="color: #800080;"&gt;0</span>; i < N1; i++<span style="color: #000000;"&gt;) {pthread_join(id1[i],NULL);}
</span><span style="color: #0000ff;"&gt;for</span>(i = <span style="color: #800080;"&gt;0</span>; i < N2; i++<span style="color: #000000;"&gt;) {pthread_join(id2[i],NULL);}

exit(</span><span style="color: #800080;"&gt;0</span><span style="color: #000000;"&gt;);

}

?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读