经典的多线程问题之一是生产者-消费者问题。该问题涉及到两个角色:生产者和消费者,它们共享一个缓冲区。生产者将产品放入缓冲区,消费者从缓冲区取出产品。但是,缓冲区有限,并且在缓冲区已满或为空时,生产者和消费者必须等待。
下面是一个使用VC++编写的生产者-消费者问题的简单示例:
#include <iostream>
#include <queue>
#include <thread>
#include <mutex>
#include <condition_variable>
std::queue<int> buffer;
const int bufferSize = 10;
std::mutex mtx;
std::condition_variable producerCV, consumerCV;
void producer() {
for (int i = 0; i < 20; ++i) {
std::unique_lock<std::mutex> lock(mtx);
producerCV.wait(lock, [] { return buffer.size() < bufferSize; });
buffer.push(i);
std::cout << "Produced: " << i << std::endl;
lock.unlock();
consumerCV.notify_one();
}
}
void consumer() {
for (int i = 0; i < 20; ++i) {
std::unique_lock<std::mutex> lock(mtx);
consumerCV.wait(lock, [] { return !buffer.empty(); });
int value = buffer.front();
buffer.pop();
std::cout << "Consumed: " << value << std::endl;
lock.unlock();
producerCV.notify_one();
}
}
int main() {
std::thread producerThread(producer);
std::thread consumerThread(consumer);
producerThread.join();
consumerThread.join();
return 0;
}
在上述示例中,我们使用一个互斥锁(std::mutex
)来保护共享资源(缓冲区)。std::condition_variable
用于在缓冲区满或为空时,生产者和消费者进行等待和通知。
producer
函数模拟生产者的行为:生产产品并将其放入缓冲区。如果缓冲区已满,生产者线程将等待,直到消费者线程取出一个产品。
consumer
函数模拟消费者的行为:从缓冲区取出产品并消费。如果缓冲区为空,消费者线程将等待,直到生产者线程放入一个产品。
在main
函数中,我们创建了两个线程分别执行生产者和消费者函数,并等待它们完成。
以上示例是一个简单的多线程问题的解决方案,但在实际应用中可能需要考虑更多的情况,如线程同步、死锁避免等。
辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>