117.info
人生若只如初见

C++循环队列的多线程应用案例

循环队列在多线程应用中经常用于实现生产者消费者模型。下面是一个简单的C++多线程应用案例,利用循环队列实现生产者消费者模型:

#include 
#include 
#include 
#include 
#include 

const int QUEUE_SIZE = 10;

std::queue q;
std::mutex mtx;
std::condition_variable cv;

void producer() {
    for (int i = 0; i < 100; ++i) {
        std::unique_lock lock(mtx);
        cv.wait(lock, []{ return q.size() < QUEUE_SIZE; });
        q.push(i);
        lock.unlock();
        cv.notify_all();
    }
}

void consumer() {
    for (int i = 0; i < 100; ++i) {
        std::unique_lock lock(mtx);
        cv.wait(lock, []{ return !q.empty(); });
        int val = q.front();
        q.pop();
        std::cout << "Consumed: " << val << std::endl;
        lock.unlock();
        cv.notify_all();
    }
}

int main() {
    std::thread prod_thread(producer);
    std::thread cons_thread(consumer);

    prod_thread.join();
    cons_thread.join();

    return 0;
}

在这个案例中,我们使用一个循环队列q来存储生产者产生的数据,队列的最大容量为QUEUE_SIZE。生产者线程不断向队列中添加数据,如果队列已满,则等待消费者线程消费数据;消费者线程不断从队列中取出数据进行消费,如果队列为空,则等待生产者线程生产数据。

通过使用互斥量mtx和条件变量cv,我们实现了线程间的同步和通信。生产者线程在生产数据时会获取互斥量,然后判断队列是否已满,如果已满则等待消费者线程通知;消费者线程在消费数据时会获取互斥量,然后判断队列是否为空,如果为空则等待生产者线程通知。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fe1b6AzsIAw9QA1U.html

推荐文章

  • C++ byte数组的大小如何确定

    C++中的byte数组大小可以通过以下两种方法确定: 使用sizeof运算符:可以通过sizeof运算符获取数组的大小,例如sizeof(arr),其中arr是byte数组的名称。这将返回...

  • C++ byte数组与性能优化技巧

    在C++中,可以使用字节数组来表示二进制数据,这在处理文件、网络数据等场景中经常会用到。以下是一些性能优化技巧,可以帮助提高字节数组的处理效率: 使用指针...

  • C++ byte数组常见的操作误区

    使用sizeof获取数组长度:在C++中,使用sizeof来获取数组的长度可能会导致错误,因为sizeof返回的是整个数组占用的内存空间大小,而不是数组中元素的个数。正确的...

  • 如何在C++中高效使用byte数组

    在C++中高效使用byte数组可以通过以下几种方式实现: 使用内置数组:可以直接声明一个byte类型的数组来存储数据。这样可以直接访问数组中的元素,不需要额外的内...

  • C++循环队列在算法竞赛中的应用

    C++循环队列在算法竞赛中经常用于解决一些需要快速插入和删除元素的问题,比如广度优先搜索(BFS)、滑动窗口等问题。循环队列可以在O(1)的时间复杂度内进行插入...

  • C++循环队列的迭代器设计

    循环队列是一种特殊的队列数据结构,它具有固定大小的缓冲区,并且在尾部插入元素时会循环回到缓冲区的起始位置。在C++中,可以通过自定义一个循环队列类来实现这...

  • C++循环队列的模板实现

    #include template class CircularQueue {
    private: int front, rear, maxSize; T* queueArray;
    public: CircularQueue(int size) { maxSize = size +...

  • C++循环队列的动态扩容机制

    循环队列是一种基于数组实现的队列,当队列满时,需要进行扩容操作。动态扩容的机制是在队列满时,创建一个新的数组,将原数组中的元素复制到新数组中,并将队列...