曾今的代码系列——生产者消费者模式

简介:

生产者消费者

例如下场景:某个模块负责产生数据,这些数据由另一个模块来负责处理(此处的模块是广义的,可以是类、函数、线程、进程等)。产生数据的模块,就形象地称为生产者;而处理数据的模块,就称为消费者

我们举一个寄信的例子,假设你要寄一封平信,大致过程如下:

  • 你把信写好——相当于生产者制造数据
  • 你把信放入邮筒——相当于生产者把数据放入缓冲区
  • 邮递员把信从邮筒取出——相当于消费者把数据取出缓冲区
  • 邮递员把信拿去邮局做相应的处理——相当于消费者处理数据

生产者消费者模式可以用来处理并发问题的。
从寄信的例子来看。如果没有邮筒,你得拿着信傻站在路口等邮递员过来收(相当于生产者阻塞);又或者邮递员得挨家挨户问,谁要寄信(相当于消费者轮询)。

复制代码
namespace 生产者消费者
{
    delegate void MyDelegate(string s);
    public partial class Form1 : Form
    {
        
        public Form1()
        {
            InitializeComponent();
            //消费者线程
            System.Threading.Thread thread = new System.Threading.Thread(() =>
            {
                while (true)
                {
                    foreach (string data in listData.ToArray())
                    {
                        MyDelegate doXF = s => txtLog.AppendText(s + "\r\n");
                        //消费
                        txtLog.Invoke(doXF, data);
                        //消费了产品之后就把它移除
                        listData.Remove(data);
                    }
                    //降低CPU压力
                    System.Threading.Thread.Sleep(5000);
                }
            });
            thread.IsBackground = true;
            thread.Start();
        }
        List<string> listData = new List<string>();
        private void btnProduct_Click(object sender, EventArgs e)
        {
            //生产
            listData.Add(txtData.Text);
            txtData.Clear();
            txtData.Focus();
        }

    }
}
复制代码

 

本博客为 木宛城主原创,基于 Creative Commons Attribution 2.5 China Mainland License发布,欢迎转载,演绎或用于商业目的,但是必须保留本文的署名 木宛城主(包含链接)。如您有任何疑问或者授权方面的协商,请给我留言。
分类: 杂谈

本文转自木宛城主博客园博客,原文链接:http://www.cnblogs.com/OceanEyes/archive/2012/09/12/2681484.html,如需转载请自行联系原作者
目录
相关文章
|
8月前
|
设计模式 安全 Java
多线程(代码案例: 单例模式, 阻塞队列, 生产者消费者模型,定时器)
多线程(代码案例: 单例模式, 阻塞队列, 生产者消费者模型,定时器)
72 2
|
8月前
|
Java C++
Java实现信号量机制(生产者消费者问题)的三种方式
Java实现信号量机制(生产者消费者问题)的三种方式
120 0
|
安全 Linux 数据安全/隐私保护
【Linux线程同步】生产者消费者模型
【Linux线程同步】生产者消费者模型
138 0
多线程实践-生产者消费者
多线程实践-生产者消费者
84 0
|
消息中间件 Java
《JUC并发编程 - 模式篇》保护性暂停模式 | 顺序控制模式 | 生产者消费者模式 | 两阶段终止模式 | Balking模式 | 享元模式(一)
《JUC并发编程 - 模式篇》保护性暂停模式 | 顺序控制模式 | 生产者消费者模式 | 两阶段终止模式 | Balking模式 | 享元模式
《JUC并发编程 - 模式篇》保护性暂停模式 | 顺序控制模式 | 生产者消费者模式 | 两阶段终止模式 | Balking模式 | 享元模式(一)
生产者消费者模式
生产者消费者模式
|
缓存 监控 安全
《JUC并发编程 - 模式篇》保护性暂停模式 | 顺序控制模式 | 生产者消费者模式 | 两阶段终止模式 | Balking模式 | 享元模式(二)
《JUC并发编程 - 模式篇》保护性暂停模式 | 顺序控制模式 | 生产者消费者模式 | 两阶段终止模式 | Balking模式 | 享元模式
《JUC并发编程 - 模式篇》保护性暂停模式 | 顺序控制模式 | 生产者消费者模式 | 两阶段终止模式 | Balking模式 | 享元模式(二)
|
缓存 Java 调度
线程协作 生产者消费者模式
线程协作 生产者消费者模式
116 0
线程协作  生产者消费者模式
|
Java 开发者
解决生产者-消费者同步问题|学习笔记
快速学习 解决生产者-消费者同步问题
158 0
解决生产者-消费者同步问题|学习笔记
基于阻塞队列实现的简单生产者-消费者模式
基于阻塞队列实现的简单生产者-消费者模式
117 0