【Linux】线程池|单例模式|STL、智能指针线程安全|读者写者问题

这是一个涉及到多个主题的问题,包括线程安全的读者-写者问题,单例模式,以及使用智能指针管理资源。以下是一个简化的示例代码,展示如何使用C++11的std::shared\_ptr和std::atomic来实现一个线程安全的单例对象池,并解决读者-写者问题。




#include <iostream>
#include <memory>
#include <mutex>
#include <atomic>
#include <list>
 
// 线程安全的对象池
template<typename T>
class ThreadSafeObjectPool {
private:
    std::list<std::shared_ptr<T>> pool;
    std::mutex mtx;
    std::atomic<bool> is_writing;
 
    ThreadSafeObjectPool(const ThreadSafeObjectPool&) = delete;
    ThreadSafeObjectPool& operator=(const ThreadSafeObjectPool&) = delete;
 
    static std::shared_ptr<ThreadSafeObjectPool<T>> instance;
 
protected:
    ThreadSafeObjectPool() : is_writing(false) {}
 
public:
    // 单例模式获取对象池实例
    static std::shared_ptr<ThreadSafeObjectPool<T>> getInstance() {
        if (!instance) {
            std::lock_guard<std::mutex> lock(mtx);
            if (!instance) {
                instance.reset(new ThreadSafeObjectPool<T>());
            }
        }
        return instance;
    }
 
    // 获取对象
    std::shared_ptr<T> getObject() {
        std::lock_guard<std::mutex> lock(mtx);
        if (pool.empty()) {
            // 如果没有可用对象,则创建一个新的对象
            return std::make_shared<T>();
        }
        auto obj = pool.front();
        pool.pop_front();
        return obj;
    }
 
    // 归还对象
    void returnObject(std::shared_ptr<T> obj) {
        std::lock_guard<std::mutex> lock(mtx);
        pool.push_back(obj);
    }
 
    // 写者请求访问
    void writerRequest() {
        while (is_writing.exchange(true)) {
            // 循环等待,直到没有其他写者
        }
    }
 
    // 写者完成访问
    void writerComplete() {
        is_writing.store(false);
    }
};
 
// 注意:以下代码需要C++11及以上支持
 
int main() {
    // 假设有一个需要线程安全的对象类型
    class Object {
    public:
        Object() { std::cout << "Object created" << std::endl; }
        ~Object() { std::cout << "Object destroyed" << std::endl; }
    };
 
    // 获取对象池实例
    auto pool = ThreadSafeObjectPool<Object>::getInstance();
 
    // 获取对象
    auto obj = pool->getObject();
 
    // 使用对象...
 
    // 归还对象
    pool->returnObject(obj);
 
    return 0;
}

这个代码示例展示了如何使用std::atomic来避免读者-写者问题,以及如何使用std::shared\_ptr和std::list来创建一个线程安全的对象池。这个对象池可以在多线程环境中安全地获取和归还对象,而不会引发数据竞争或内存泄漏。

最后修改于:2024年08月23日 12:45

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日