当前位置:   article > 正文

C++多线程编程——线程同步:生产者与消费者问题_posix c++ 共享内存 消费者 生产者 full

posix c++ 共享内存 消费者 生产者 full

生产者与消费者问题是多线程中非常经典的线程同步问题,这些线程必须按照一定的生产率和消费率来访问共享缓冲区。

实现方法是:设置两个信号量full和empty,其中full表示消费缓冲区的个数,empty表示生产缓冲区的个数,初始时没有生产物品,所以full值为0,empty值为n(n表示最大生产数量)。当生产者生产时,需要等待进入生产缓冲区,然后生产物品,生产完成后将消费缓冲区+1;当消费者消费时,需要等待进入消费缓冲区,然后消费物品,消费完成后将生产缓冲区+1;其实现代码如下:

  1. #include <windows.h>
  2. #include <iostream>
  3. using namespace std;
  4. //创建生产、消费信号量
  5. HANDLE s_full = CreateSemaphore(NULL, 0, 1, NULL);
  6. HANDLE s_empty = CreateSemaphore(NULL, 1, 1, NULL);
  7. //创建互斥量
  8. HANDLE mutex = CreateMutex(NULL, false, NULL);
  9. //生产者线程
  10. DWORD WINAPI Producer(LPVOID plParamter)
  11. {
  12. int *k = (int*)plParamter;
  13. for (int i = 0; i < 100; i++)
  14. {
  15. //等待空的缓冲区域
  16. WaitForSingleObject(s_empty, INFINITE);
  17. //等待进入临界区
  18. //WaitForSingleObject(mutex, INFINITE);
  19. //进行生产
  20. (*k)++;
  21. cout << "produce:" << *k << endl;
  22. //退出临界区
  23. //ReleaseMutex(mutex);
  24. //消费缓冲区+1
  25. ReleaseSemaphore(s_full, 1, NULL);
  26. Sleep(500);
  27. }
  28. return 0L;
  29. }
  30. DWORD WINAPI Consumer(LPVOID plParamter)
  31. {
  32. int *k = (int*)plParamter;
  33. for (int i = 0; i < 100; i++)
  34. {
  35. //等待消费的缓冲区域
  36. WaitForSingleObject(s_full, INFINITE);
  37. //等待进入临界区
  38. //WaitForSingleObject(mutex, INFINITE);
  39. //进行消费
  40. cout << "comsume:" << (*k) << endl;
  41. //退出临界区
  42. //ReleaseMutex(mutex);
  43. //空缓冲区+1
  44. ReleaseSemaphore(s_empty, 1, NULL);
  45. Sleep(500);
  46. }
  47. return 0L;
  48. }
  49. int main()
  50. {
  51. int k = 0;
  52. {
  53. //创建生产者进程
  54. HANDLE h1 = CreateThread(NULL, 0, Producer, (void*)&k, NULL, NULL);
  55. //创建消费者进程
  56. HANDLE h2 = CreateThread(NULL, 0, Consumer, (void*)&k, NULL, NULL);
  57. //关闭进程句柄,释放资源
  58. CloseHandle(h1);
  59. CloseHandle(h2);
  60. }
  61. Sleep(50000);
  62. return 0;
  63. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/267913
推荐阅读
  

闽ICP备14008679号