下面着重介绍C++多线程,C++多线程为了同步完成了多项任务,而且很大程度的提高了资源使用效率,用较简单的话语解释C++多线程问题,它就是在同一时间内完成多项任务。
重要区段(TCriticalSection)和事件(TEvent)得到了应用。生产者通过TEvent类的对象Begin Consume来通知消费者开始消费,而消费者通过TEent类的对象Begin Produce通知生产者开始生产。程序中共有两个生产者,一个消费者。在两个生产者之间,通过TCriticalSection类的对象同步。其运行界面如图1所示。
主要源程序如下所示:生产者线程:
- Void __fast call TProducerThread:: Execute ()
- {
- //---- Place thread code here ----
- Int i = 0;
- Int j;
- while(i<100) //每个生产者线程生产100个商品
- {
- Sleep(1000);//延迟,为清楚得显示执行效果
- if(Form1->buffer_size > 0)//缓冲池不空,通知消费者消费
- {
- Form1->Begin Consumer->Set Event ();
- }
- Form1->Produce Guard->Acquire ();
- i++;
- StrResult = IntToStr (i);
- J = Form1->buffer_size;
- Form1->Product [j] = i;
- Form1->buffer_size++;
- Synchronize(Show Result);//刷新界面,显示最新生产-消费状况
- Form1->Begin Consumer->Set Event();//通知消费者消费
- if(Form1->buffer_size == 5)//缓冲池满,挂起生产者线程,直到通知再生产
- {
- Form1->Begin Produce->Wait For (INFINITE);
- }
- Sleep (1000);
- Form1->Produce Guard->Release ();
- }
- While (Form1->buffer_size > 0)
- {
- Form1->Begin Consumer->Set Event ();
- }
- }
消费者线程:
- Void __fast call TConsumerThread::Execute()
- {
- //---- Place thread code here ----
- Int j;
- For (int i = 0;i < 200;i++)
- {
- Sleep(100); //延迟,为清楚得显示执行效果
- Form1->Begin Consumer->Wait For(INFINITE);//挂起消费者线程,直到通知再消费
- J = Form1->buffer_size - 1;
- StrResult = IntToStr (Form1->Product [j]);
- Form1->buffer_size--;
- Synchronize(Show Result); //刷新界面,显示最新生产-消费状况
- if(Form1->buffer_size == 4)//缓冲池不再full,唤醒由于缓冲池full而挂起的生产者线程
- {
- Form1->Begin Produce->Set Event ();
- }
- Sleep (100);
- }
- }
本文讨论了C++多线程编程及其可行性,说明了在Windows环境下进行C++多线程编程的意义,并重点讨论了C++Builder平台下如何开发多线程应用程序这一问题,通过实现"生产者-消费者问题"这一著名的进程同步问题,比较清晰地反映了在Windows环境下进行多线程编程技术及其实现的作用和效果。
【编辑推荐】