C++设计模式-更新中

单例模式

这个类实现了单例模式。单例模式是一种设计模式,旨在确保一个类只有一个实例,并提供一个全局访问点来获取该实例。

ConnectionManager 类中,它通过以下方式实现了单例模式:

  1. 构造函数 ConnectionManager() 被声明为私有外部无法直接创建类的实例。
  2. 通过静态成员函数 getInstance() 来获取 ConnectionManager 类的实例。该函数使用了一个静态的 ConnectionManager 类型对象,并在首次调用时创建该对象,并保证只有一个实例被创建。
  3. 复制构造函数和赋值运算符被删除,禁止直接进行对象的拷贝构造和赋值操作,确保只有一个实例存在。

通过实现这些特性,ConnectionManager 类确保只能通过单例实例来访问和操作类的方法和成员变量,从而实现了单例模式。

cpp 复制代码
#ifndef RDMA_SERVER_CONNECTIONMANAGER_H
#define RDMA_SERVER_CONNECTIONMANAGER_H

#pragma once

#include "../common/common.h"
#include "../queue_manager/QueueManager.h"
#include "../buffer_manager/BufferManager.h"
#include "./Connection.h"
// 是的,这个类实现了单例模式。单例模式是一种设计模式,旨在确保一个类只有一个实例,并提供一个全局访问点来获取该实例。

// 在 `ConnectionManager` 类中,它通过以下方式实现了单例模式:

// 1. 构造函数 `ConnectionManager()` 被声明为私有,外部无法直接创建类的实例。
// 2. 通过静态成员函数 `getInstance()` 来获取 `ConnectionManager` 类的实例。该函数使用了一个静态的 `ConnectionManager` 类型对象,
//并在首次调用时创建该对象,并保证只有一个实例被创建。
// 3. 复制构造函数和赋值运算符被删除,禁止直接进行对象的拷贝构造和赋值操作,确保只有一个实例存在。

// 通过实现这些特性,`ConnectionManager` 类确保只能通过单例实例来访问和操作类的方法和成员变量,从而实现了单例模式。
class ConnectionManager {
public:
//单例模式
    static ConnectionManager &getInstance();

    ConnectionManager(ConnectionManager const &) = delete;

    void operator=(ConnectionManager const &) = delete;

    ~ConnectionManager();

    Connection *create(struct ibv_device *);

    void destroy(Connection *);

    struct ibv_qp *createQueuePair(Connection *, struct ibv_qp_attr *);

    void connectQueuePair(Connection *, uint32_t, uint32_t, ibv_mtu, struct ibv_qp_attr *);

    void resetQueuePair(struct ibv_qp *, struct ibv_qp_attr *);

private:
    ConnectionManager();

    std::shared_ptr<spdlog::logger> logger = nullptr;

    std::shared_ptr<QueueManager> queueManager = std::make_shared<QueueManager>();

    std::mutex queuePairsMtx;
};

#endif
相关推荐
coderlin_36 分钟前
BI布局拖拽 (1) 深入react-gird-layout源码
android·javascript·react.js
伍哥的传说1 小时前
React 实现五子棋人机对战小游戏
前端·javascript·react.js·前端框架·node.js·ecmascript·js
我在北京coding1 小时前
element el-table渲染二维对象数组
前端·javascript·vue.js
布兰妮甜1 小时前
Vue+ElementUI聊天室开发指南
前端·javascript·vue.js·elementui
SevgiliD1 小时前
el-button传入icon用法可能会出现的问题
前端·javascript·vue.js
我在北京coding1 小时前
Element-Plus-全局自动引入图标组件,无需每次import
前端·javascript·vue.js
鱼 空1 小时前
解决el-table右下角被挡住部分
javascript·vue.js·elementui
小李飞飞砖2 小时前
React Native 组件间通信方式详解
javascript·react native·react.js
小李飞飞砖2 小时前
React Native 状态管理方案全面对比
javascript·react native·react.js
蜉蝣之翼❉4 小时前
CRT 不同会导致 fopen 地址不同
c++·mfc