生产者和消费者

好几天没有写日记了,我觉得我该补上。

刚好这几天在帮人家写几个程序,我就复习吧。

今天写个生产者和消费者,温习下多线程和互斥变量的用法吧。

在操作系统课程内有临界区的说法,在windows下存在类型CRITICAL_SECTION,这就是个互斥变量,我一般就喜欢叫做锁,虽然这样叫有点欠妥~~~~~~~~~~

CRITICAL_SECTION 使用步骤分3步。

第一:初始化该变量-----------------------------InitializeCriticalSection(LPCRITICAL_SECTION);

第二:使用该变量进行互斥访问-----------------EnterCriticalSection,LeaveCriticalSection

第三:在结束了对该变量的使用后,别忘记删除该变量哦。DeleteCriticalSection

 

附代码:

 

CRITICAL_SECTION xLock;
int ntest = 0;
int nStore[20];

 

 

DWORD WINAPI Producer(LPVOID param)
{
 int i=0;
 while(i<20 && ntest>=0 )
 {
  if(ntest<20)//存储空间未满
  {
   EnterCriticalSection(&xLock);
   nStore[ntest++] = 1;//存储
   cout<<"生产者"<<endl;
   LeaveCriticalSection(&xLock);
   i++;
   Sleep(8);
  }

 }
 return 0;
}

 

 

DWORD WINAPI Consumer(LPVOID param)
{
 int i=0;
 while (i<20 )
 {
  if (ntest>0)//仓库仍有货物
  {
   EnterCriticalSection(&xLock);
   ntest--;//消费
   cout<<"消费者"<<endl;
   i++;
   LeaveCriticalSection(&xLock);
   Sleep(16);
  }

 }
 return 0;

 

 

 

int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{
 int nRetCode = 0;
 HANDLE hThread[2];

 InitializeCriticalSection(&xLock);
 hThread[0] = CreateThread(NULL,0,Producer,NULL,0,NULL);
 hThread[1] = CreateThread(NULL,0,Consumer,NULL,0,NULL);
 WaitForMultipleObjects(2, hThread, TRUE, INFINITE);
  for (int i=0;i<2;i++)
 {
  CloseHandle(hThread[i]);
 }

DeleteCriticalSection(&xLock);
 return nRetCode;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,"生产者-消费者"(Producer-Consumer)模式是一种经典的设计模式,用于解决多线程环境中的同步问题。它定义了两个角色,即生产者(Producer)和消费者(Consumer),它们分别负责创建数据(产品)和消费数据。 **1. 生产者(Producer):** 生产者通常在自己的线程中不断产生新的对象,并将这些对象添加到一个共享的队列(如`BlockingQueue`、`ArrayBlockingQueue`等)中。生产者需要处理可能的数据溢出(队列已满)和资源竞争(队列为空)。 **2. 消费者(Consumer):** 消费者从队列中取出数据并进行处理,消耗掉生产者产生的对象。同样,消费者需要处理可能的数据饥饿(队列空)和资源竞争(队列满)。 **3. 同步机制:** 为了确保生产者消费者之间的同步,Java提供了`synchronized`关键字或`Semaphore`、`CountDownLatch`、`CyclicBarrier`等并发工具。使用这些工具可以控制访问队列的权限,避免数据不一致或死锁。 **4. 示例代码:** 下面是一个简单的`BlockingQueue`实现的生产者消费者示例: ```java import java.util.concurrent.*; public class ProducerConsumer { private final BlockingQueue<String> queue = new LinkedBlockingQueue<>(10); private final Thread producer; private final Thread consumer; public ProducerConsumer() { producer = new Thread(() -> produceData()); consumer = new Thread(() -> consumeData()); producer.start(); consumer.start(); } private void produceData() { while (true) { synchronized (queue) { if (queue.isEmpty()) { try { queue.wait(); // 队列空时等待 } catch (InterruptedException e) { e.printStackTrace(); } } String data = generateData(); // 生产数据 queue.offer(data); // 添加到队列 System.out.println("Produced: " + data); queue.notify(); // 唤醒消费者 } } } private void consumeData() { while (true) { synchronized (queue) { if (queue.isEmpty()) { try { queue.wait(); // 队列空时等待 } catch (InterruptedException e) { e.printStackTrace(); } } String data = queue.take(); // 从队列获取数据 System.out.println("Consumed: " + data); } } } private String generateData() { // 实现数据生成逻辑 return "Data " + UUID.randomUUID().toString(); } public static void main(String[] args) { new ProducerConsumer(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值